xref: /netbsd-src/sys/modules/panic/panic.c (revision 31510453944a10501ce606a0b8c7e5d36d433e6e)
1*31510453Schristos /* $NetBSD: panic.c,v 1.2 2021/06/21 03:08:07 christos Exp $ */
26c491947Sjmcneill 
36c491947Sjmcneill /*
46c491947Sjmcneill  * Copyright (c) 2011 Jared D. McNeill <jmcneill@invisible.ca>
56c491947Sjmcneill  * All rights reserved.
66c491947Sjmcneill  *
76c491947Sjmcneill  * Redistribution and use in source and binary forms, with or without
86c491947Sjmcneill  * modification, are permitted provided that the following conditions
96c491947Sjmcneill  * are met:
106c491947Sjmcneill  * 1. Redistributions of source code must retain the above copyright
116c491947Sjmcneill  *    notice, this list of conditions and the following disclaimer.
126c491947Sjmcneill  * 2. The name of the author may not be used to endorse or promote products
136c491947Sjmcneill  *    derived from this software without specific prior written permission.
146c491947Sjmcneill  *
156c491947Sjmcneill  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
166c491947Sjmcneill  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
176c491947Sjmcneill  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
186c491947Sjmcneill  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
196c491947Sjmcneill  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
206c491947Sjmcneill  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
216c491947Sjmcneill  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
226c491947Sjmcneill  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
236c491947Sjmcneill  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
246c491947Sjmcneill  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
256c491947Sjmcneill  * SUCH DAMAGE.
266c491947Sjmcneill  */
276c491947Sjmcneill 
286c491947Sjmcneill #include <sys/cdefs.h>
29*31510453Schristos __KERNEL_RCSID(0, "$NetBSD: panic.c,v 1.2 2021/06/21 03:08:07 christos Exp $");
306c491947Sjmcneill 
316c491947Sjmcneill #include <sys/module.h>
326c491947Sjmcneill 
336c491947Sjmcneill MODULE(MODULE_CLASS_MISC, panic, NULL);
346c491947Sjmcneill 
356c491947Sjmcneill static void
panic_dopanic(void)366c491947Sjmcneill panic_dopanic(void)
376c491947Sjmcneill {
386c491947Sjmcneill 	/* just call panic */
396c491947Sjmcneill 	panic("oops");
406c491947Sjmcneill }
416c491947Sjmcneill 
426c491947Sjmcneill static void
panic_donullptr(void)436c491947Sjmcneill panic_donullptr(void)
446c491947Sjmcneill {
456c491947Sjmcneill 	/* null ptr dereference */
466c491947Sjmcneill 	*(int *)NULL = 1;
476c491947Sjmcneill }
486c491947Sjmcneill 
496c491947Sjmcneill static const struct {
506c491947Sjmcneill 	const char *name;
516c491947Sjmcneill 	void (*func)(void);
526c491947Sjmcneill } panic_howto[] = {
536c491947Sjmcneill 	{ "panic",	panic_dopanic },
546c491947Sjmcneill 	{ "nullptr",	panic_donullptr },
556c491947Sjmcneill };
566c491947Sjmcneill 
576c491947Sjmcneill static int
panic_modcmd(modcmd_t cmd,void * opaque)586c491947Sjmcneill panic_modcmd(modcmd_t cmd, void *opaque)
596c491947Sjmcneill {
606c491947Sjmcneill 	if (cmd == MODULE_CMD_INIT) {
616c491947Sjmcneill 		prop_dictionary_t props = opaque;
626c491947Sjmcneill 		const char *how = NULL;
636c491947Sjmcneill 		unsigned int i;
646c491947Sjmcneill 
656c491947Sjmcneill 		if (props)
66*31510453Schristos 			prop_dictionary_get_string(props, "how", &how);
676c491947Sjmcneill 		if (how == NULL)
686c491947Sjmcneill 			how = "panic";
696c491947Sjmcneill 
706c491947Sjmcneill 		for (i = 0; i < __arraycount(panic_howto); i++) {
716c491947Sjmcneill 			if (strcmp(how, panic_howto[i].name) == 0) {
726c491947Sjmcneill 				panic_howto[i].func();
736c491947Sjmcneill 				break;
746c491947Sjmcneill 			}
756c491947Sjmcneill 		}
766c491947Sjmcneill 		if (i == __arraycount(panic_howto))
776c491947Sjmcneill 			printf("%s: no how '%s'\n", __func__, how);
786c491947Sjmcneill 		else
796c491947Sjmcneill 			printf("%s: how '%s' didn't panic?\n", __func__, how);
806c491947Sjmcneill 
816c491947Sjmcneill 		return EINVAL;
826c491947Sjmcneill 	}
836c491947Sjmcneill 
846c491947Sjmcneill 	return ENOTTY;
856c491947Sjmcneill }
86