root/usr/src/cmd/mdb/common/kmdb/kmdb_stubs.c
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (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 2006 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

/*
 * Stubs for basic system services otherwise unavailable to the debugger.
 */

#include <stdlib.h>
#include <unistd.h>
#include <libproc.h>
#include <sys/time.h>

#include <kmdb/kmdb_dpi.h>
#include <kmdb/kmdb_promif.h>
#include <kmdb/kmdb_io.h>
#include <mdb/mdb_debug.h>
#include <mdb/mdb_signal.h>
#include <mdb/mdb_io_impl.h>
#include <mdb/mdb.h>

/*ARGSUSED*/
char *
getenv(const char *name)
{
        /* There aren't any environment variables here */
        return (NULL);
}

char *
strerror(int errnum)
{
        static char errnostr[16];

        (void) mdb_snprintf(errnostr, sizeof (errnostr), "Error %d", errnum);

        return (errnostr);
}

pid_t
getpid(void)
{
        return (1);
}

/*
 * We're trying to isolate ourselves from the rest of the world as much as
 * possible, so we can't rely on the time in the kernel proper.  For now, we
 * just bump a counter whenever time is requested, thus guaranteeing that
 * things with timestamps can be compared according to order of occurrance.
 */
hrtime_t
gethrtime(void)
{
        static hrtime_t kmdb_timestamp;

        return (++kmdb_timestamp);
}

/*
 * Signal handling
 */

/*ARGSUSED*/
int
sigemptyset(sigset_t *set)
{
        return (0);
}

/*ARGSUSED*/
int
sigaddset(sigset_t *set, int signo)
{
        return (0);
}

/*ARGSUSED*/
int
sigfillset(sigset_t *set)
{
        return (0);
}

/*ARGSUSED*/
int
sigprocmask(int how, const sigset_t *set, sigset_t *oset)
{
        return (0);
}

/*ARGSUSED*/
int
sigaction(int sig, const struct sigaction *act, struct sigaction *oact)
{
        return (0);
}

/*ARGSUSED*/
int
kill(pid_t pid, int sig)
{
        if (sig == SIGABRT) {
                mdb_printf("Debugger aborted\n");
                exit(1);
        }

        return (0);
}

/*ARGSUSED*/
int
proc_str2flt(const char *buf, int *ptr)
{
        return (-1);
}

/*ARGSUSED*/
int
proc_str2sig(const char *buf, int *ptr)
{
        return (-1);
}

/*ARGSUSED*/
int
proc_str2sys(const char *buf, int *ptr)
{
        return (-1);
}

/*ARGSUSED*/
void
exit(int status)
{
#ifdef __sparc
        extern void kmdb_prom_exit_to_mon(void) __NORETURN;

        kmdb_prom_exit_to_mon();
#else
        extern void kmdb_dpi_reboot(void) __NORETURN;
        static int recurse = 0;

        if (!recurse) {

                recurse = 1;

                mdb_iob_printf(mdb.m_out, "Press any key to reboot\n");
                mdb_iob_flush(mdb.m_out);
                mdb_iob_clearlines(mdb.m_out);

                (void) kmdb_getchar();
        }

        kmdb_dpi_reboot();
#endif
}