/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright (c) 1998-1999 by Sun Microsystems, Inc. * All rights reserved. */ #pragma ident "%Z%%M% %I% %E% SMI" #include <sys/mdb_modapi.h> #include <sys/sysinfo.h> /* * simple_echo dcmd - Demonstrate some simple argument processing by iterating * through the argument array and printing back each argument. */ static int simple_echo(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv) { if (flags & DCMD_ADDRSPEC) mdb_printf("You specified address %p\n", addr); else mdb_printf("Current address is %p\n", addr); while (argc-- != 0) { if (argv->a_type == MDB_TYPE_STRING) mdb_printf("%s ", argv->a_un.a_str); else mdb_printf("%llr ", argv->a_un.a_val); argv++; } mdb_printf("\n"); return (DCMD_OK); } /* * vminfo dcmd - Print out the global vminfo structure, nicely formatted. * This function illustrates one of the functions for reading data from * the target program (or core file): mdb_readvar(). The vminfo_t * structure contains cumulative counters for various system virtual * memory statistics. Each second, these are incremented by the current * values of freemem and the other corresponding statistical counters. */ /*ARGSUSED*/ static int vminfo(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv) { vminfo_t vm; if ((flags & DCMD_ADDRSPEC) || argc != 0) return (DCMD_USAGE); if (mdb_readvar(&vm, "vminfo") == -1) { /* * If the mdb_warn string does not end in a \n, mdb will * automatically append the reason for the failure. */ mdb_warn("failed to read vminfo structure"); return (DCMD_ERR); } mdb_printf("Cumulative memory statistics:\n"); mdb_printf("%8llu pages of free memory\n", vm.freemem); mdb_printf("%8llu pages of reserved swap\n", vm.swap_resv); mdb_printf("%8llu pages of allocated swap\n", vm.swap_alloc); mdb_printf("%8llu pages of unreserved swap\n", vm.swap_avail); mdb_printf("%8llu pages of unallocated swap\n", vm.swap_free); return (DCMD_OK); } /* * MDB module linkage information: * * We declare a list of structures describing our dcmds, and a function * named _mdb_init to return a pointer to our module information. */ static const mdb_dcmd_t dcmds[] = { { "simple_echo", "[ args ... ]", "echo back arguments", simple_echo }, { "vminfo", NULL, "print vm information", vminfo }, { NULL } }; static const mdb_modinfo_t modinfo = { MDB_API_VERSION, dcmds, NULL }; const mdb_modinfo_t * _mdb_init(void) { return (&modinfo); }