1bd3cdc31SAndrzej Bialecki /*- 2*b61a5730SWarner Losh * SPDX-License-Identifier: BSD-2-Clause 3f0cfa1b1SPedro F. Giffuni * 4bd3cdc31SAndrzej Bialecki * Copyright (c) 2000 Andrzej Bialecki <abial@freebsd.org> 5bd3cdc31SAndrzej Bialecki * All rights reserved. 6bd3cdc31SAndrzej Bialecki * 7bd3cdc31SAndrzej Bialecki * Redistribution and use in source and binary forms, with or without 8bd3cdc31SAndrzej Bialecki * modification, are permitted provided that the following conditions 9bd3cdc31SAndrzej Bialecki * are met: 10bd3cdc31SAndrzej Bialecki * 1. Redistributions of source code must retain the above copyright 11bd3cdc31SAndrzej Bialecki * notice, this list of conditions and the following disclaimer. 12bd3cdc31SAndrzej Bialecki * 2. Redistributions in binary form must reproduce the above copyright 13bd3cdc31SAndrzej Bialecki * notice, this list of conditions and the following disclaimer in the 14bd3cdc31SAndrzej Bialecki * documentation and/or other materials provided with the distribution. 15bd3cdc31SAndrzej Bialecki * 16bd3cdc31SAndrzej Bialecki * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17bd3cdc31SAndrzej Bialecki * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18bd3cdc31SAndrzej Bialecki * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19bd3cdc31SAndrzej Bialecki * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20bd3cdc31SAndrzej Bialecki * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21bd3cdc31SAndrzej Bialecki * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22bd3cdc31SAndrzej Bialecki * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23bd3cdc31SAndrzej Bialecki * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24bd3cdc31SAndrzej Bialecki * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25bd3cdc31SAndrzej Bialecki * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26bd3cdc31SAndrzej Bialecki * SUCH DAMAGE. 27bd3cdc31SAndrzej Bialecki * 28bd3cdc31SAndrzej Bialecki * $FreeBSD$ 29bd3cdc31SAndrzej Bialecki */ 30bd3cdc31SAndrzej Bialecki 31bd3cdc31SAndrzej Bialecki #include <sys/types.h> 32bd3cdc31SAndrzej Bialecki #include <sys/param.h> 33bd3cdc31SAndrzej Bialecki #include <sys/systm.h> 34bd3cdc31SAndrzej Bialecki #include <sys/module.h> 35bd3cdc31SAndrzej Bialecki #include <sys/sysctl.h> 36bd3cdc31SAndrzej Bialecki #include <sys/kernel.h> 37bd3cdc31SAndrzej Bialecki 38bd3cdc31SAndrzej Bialecki 39bd3cdc31SAndrzej Bialecki /* Some example data */ 40bd3cdc31SAndrzej Bialecki static long a = 100; 41bd3cdc31SAndrzej Bialecki static int b = 200; 42bd3cdc31SAndrzej Bialecki static char *c = "hi there from dyn_sysctl"; 43bd3cdc31SAndrzej Bialecki static struct sysctl_oid *a_root, *a_root1, *b_root; 44bd3cdc31SAndrzej Bialecki static struct sysctl_ctx_list clist, clist1, clist2; 45bd3cdc31SAndrzej Bialecki 46bd3cdc31SAndrzej Bialecki static int 47bd3cdc31SAndrzej Bialecki sysctl_dyn_sysctl_test(SYSCTL_HANDLER_ARGS) 48bd3cdc31SAndrzej Bialecki { 49bd3cdc31SAndrzej Bialecki char *buf = "let's produce some text..."; 50bd3cdc31SAndrzej Bialecki 51bd3cdc31SAndrzej Bialecki return (sysctl_handle_string(oidp, buf, strlen(buf), req)); 52bd3cdc31SAndrzej Bialecki } 53bd3cdc31SAndrzej Bialecki 54bd3cdc31SAndrzej Bialecki /* 55bd3cdc31SAndrzej Bialecki * The function called at load/unload. 56bd3cdc31SAndrzej Bialecki */ 57bd3cdc31SAndrzej Bialecki static int 58bd3cdc31SAndrzej Bialecki load(module_t mod, int cmd, void *arg) 59bd3cdc31SAndrzej Bialecki { 60bd3cdc31SAndrzej Bialecki int error; 61bd3cdc31SAndrzej Bialecki 62bd3cdc31SAndrzej Bialecki error = 0; 63bd3cdc31SAndrzej Bialecki switch (cmd) { 64bd3cdc31SAndrzej Bialecki case MOD_LOAD: 65bd3cdc31SAndrzej Bialecki /* Initialize the contexts */ 66bd3cdc31SAndrzej Bialecki printf("Initializing contexts and creating subtrees.\n\n"); 67bd3cdc31SAndrzej Bialecki sysctl_ctx_init(&clist); 68bd3cdc31SAndrzej Bialecki sysctl_ctx_init(&clist1); 69bd3cdc31SAndrzej Bialecki sysctl_ctx_init(&clist2); 70bd3cdc31SAndrzej Bialecki /* 71bd3cdc31SAndrzej Bialecki * Create two partially overlapping subtrees, belonging 72bd3cdc31SAndrzej Bialecki * to different contexts. 73bd3cdc31SAndrzej Bialecki */ 74bd3cdc31SAndrzej Bialecki printf("TREE ROOT NAME\n"); 750004c28dSOleksandr Tymoshenko a_root = SYSCTL_ADD_ROOT_NODE(&clist, 7604d94960SAndrzej Bialecki OID_AUTO, "dyn_sysctl", CTLFLAG_RW, 0, 77bd3cdc31SAndrzej Bialecki "dyn_sysctl root node"); 780004c28dSOleksandr Tymoshenko a_root = SYSCTL_ADD_ROOT_NODE(&clist1, 7904d94960SAndrzej Bialecki OID_AUTO, "dyn_sysctl", CTLFLAG_RW, 0, 80bd3cdc31SAndrzej Bialecki "dyn_sysctl root node"); 81bd3cdc31SAndrzej Bialecki if (a_root == NULL) { 82bd3cdc31SAndrzej Bialecki printf("SYSCTL_ADD_NODE failed!\n"); 83bd3cdc31SAndrzej Bialecki return (EINVAL); 84bd3cdc31SAndrzej Bialecki } 85bd3cdc31SAndrzej Bialecki SYSCTL_ADD_LONG(&clist, SYSCTL_CHILDREN(a_root), 8604d94960SAndrzej Bialecki OID_AUTO, "long_a", CTLFLAG_RW, &a, "just to try"); 87bd3cdc31SAndrzej Bialecki SYSCTL_ADD_INT(&clist, SYSCTL_CHILDREN(a_root), 8804d94960SAndrzej Bialecki OID_AUTO, "int_b", CTLFLAG_RW, &b, 0, "just to try 1"); 89bd3cdc31SAndrzej Bialecki a_root1 = SYSCTL_ADD_NODE(&clist, SYSCTL_CHILDREN(a_root), 9004d94960SAndrzej Bialecki OID_AUTO, "nextlevel", CTLFLAG_RD, 0, "one level down"); 91bd3cdc31SAndrzej Bialecki SYSCTL_ADD_STRING(&clist, SYSCTL_CHILDREN(a_root1), 9204d94960SAndrzej Bialecki OID_AUTO, "string_c", CTLFLAG_RD, c, 0, "just to try 2"); 93bd3cdc31SAndrzej Bialecki printf("1. (%p) / dyn_sysctl\n", &clist); 94bd3cdc31SAndrzej Bialecki 95bd3cdc31SAndrzej Bialecki /* Add a subtree under already existing category */ 96bd3cdc31SAndrzej Bialecki a_root1 = SYSCTL_ADD_NODE(&clist, SYSCTL_STATIC_CHILDREN(_kern), 9704d94960SAndrzej Bialecki OID_AUTO, "dyn_sysctl", CTLFLAG_RW, 0, "dyn_sysctl root node"); 98bd3cdc31SAndrzej Bialecki if (a_root1 == NULL) { 99bd3cdc31SAndrzej Bialecki printf("SYSCTL_ADD_NODE failed!\n"); 100bd3cdc31SAndrzej Bialecki return (EINVAL); 101bd3cdc31SAndrzej Bialecki } 102bd3cdc31SAndrzej Bialecki SYSCTL_ADD_PROC(&clist, SYSCTL_CHILDREN(a_root1), 103f4f04709SMatthew D Fleming OID_AUTO, "procedure", CTLTYPE_STRING | CTLFLAG_RD, 104f4f04709SMatthew D Fleming NULL, 0, sysctl_dyn_sysctl_test, "A", 105f4f04709SMatthew D Fleming "I can be here, too"); 106bd3cdc31SAndrzej Bialecki printf(" (%p) /kern dyn_sysctl\n", &clist); 107bd3cdc31SAndrzej Bialecki 108bd3cdc31SAndrzej Bialecki /* Overlap second tree with the first. */ 109bd3cdc31SAndrzej Bialecki b_root = SYSCTL_ADD_NODE(&clist1, SYSCTL_CHILDREN(a_root), 11004d94960SAndrzej Bialecki OID_AUTO, "nextlevel", CTLFLAG_RD, 0, "one level down"); 111bd3cdc31SAndrzej Bialecki SYSCTL_ADD_STRING(&clist1, SYSCTL_CHILDREN(b_root), 11204d94960SAndrzej Bialecki OID_AUTO, "string_c1", CTLFLAG_RD, c, 0, "just to try 2"); 113bd3cdc31SAndrzej Bialecki printf("2. (%p) / dyn_sysctl (overlapping #1)\n", &clist1); 114bd3cdc31SAndrzej Bialecki 115bd3cdc31SAndrzej Bialecki /* 116bd3cdc31SAndrzej Bialecki * And now do something stupid. Connect another subtree to 117bd3cdc31SAndrzej Bialecki * dynamic oid. 118bd3cdc31SAndrzej Bialecki * WARNING: this is an example of WRONG use of dynamic sysctls. 119bd3cdc31SAndrzej Bialecki */ 120bd3cdc31SAndrzej Bialecki b_root=SYSCTL_ADD_NODE(&clist2, SYSCTL_CHILDREN(a_root1), 12104d94960SAndrzej Bialecki OID_AUTO, "bad", CTLFLAG_RW, 0, "dependent node"); 122bd3cdc31SAndrzej Bialecki SYSCTL_ADD_STRING(&clist2, SYSCTL_CHILDREN(b_root), 12304d94960SAndrzej Bialecki OID_AUTO, "string_c", CTLFLAG_RD, c, 0, "shouldn't panic"); 124bd3cdc31SAndrzej Bialecki printf("3. (%p) /kern/dyn_sysctl bad (WRONG!)\n", &clist2); 125bd3cdc31SAndrzej Bialecki break; 126bd3cdc31SAndrzej Bialecki case MOD_UNLOAD: 127bd3cdc31SAndrzej Bialecki printf("1. Try to free ctx1 (%p): ", &clist); 128195ebc7eSPawel Jakub Dawidek if (sysctl_ctx_free(&clist) != 0) 129bd3cdc31SAndrzej Bialecki printf("failed: expected. Need to remove ctx3 first.\n"); 130bd3cdc31SAndrzej Bialecki else 131bd3cdc31SAndrzej Bialecki printf("HELP! sysctl_ctx_free(%p) succeeded. EXPECT PANIC!!!\n", &clist); 132bd3cdc31SAndrzej Bialecki printf("2. Try to free ctx3 (%p): ", &clist2); 133195ebc7eSPawel Jakub Dawidek if (sysctl_ctx_free(&clist2) != 0) { 134bd3cdc31SAndrzej Bialecki printf("sysctl_ctx_free(%p) failed!\n", &clist2); 135bd3cdc31SAndrzej Bialecki /* Remove subtree forcefully... */ 136bd3cdc31SAndrzej Bialecki sysctl_remove_oid(b_root, 1, 1); 137bd3cdc31SAndrzej Bialecki printf("sysctl_remove_oid(%p) succeeded\n", b_root); 138bd3cdc31SAndrzej Bialecki } else 139bd3cdc31SAndrzej Bialecki printf("Ok\n"); 140bd3cdc31SAndrzej Bialecki printf("3. Try to free ctx1 (%p) again: ", &clist); 141195ebc7eSPawel Jakub Dawidek if (sysctl_ctx_free(&clist) != 0) { 142bd3cdc31SAndrzej Bialecki printf("sysctl_ctx_free(%p) failed!\n", &clist); 143bd3cdc31SAndrzej Bialecki /* Remove subtree forcefully... */ 144bd3cdc31SAndrzej Bialecki sysctl_remove_oid(a_root1, 1, 1); 145bd3cdc31SAndrzej Bialecki printf("sysctl_remove_oid(%p) succeeded\n", a_root1); 146bd3cdc31SAndrzej Bialecki } else 147bd3cdc31SAndrzej Bialecki printf("Ok\n"); 148bd3cdc31SAndrzej Bialecki printf("4. Try to free ctx2 (%p): ", &clist1); 149195ebc7eSPawel Jakub Dawidek if (sysctl_ctx_free(&clist1) != 0) { 150bd3cdc31SAndrzej Bialecki printf("sysctl_ctx_free(%p) failed!\n", &clist1); 151bd3cdc31SAndrzej Bialecki /* Remove subtree forcefully... */ 152bd3cdc31SAndrzej Bialecki sysctl_remove_oid(a_root, 1, 1); 153bd3cdc31SAndrzej Bialecki } else 154bd3cdc31SAndrzej Bialecki printf("Ok\n"); 155bd3cdc31SAndrzej Bialecki break; 156bd3cdc31SAndrzej Bialecki default: 15774bf4e16SPawel Jakub Dawidek error = EOPNOTSUPP; 158bd3cdc31SAndrzej Bialecki break; 159bd3cdc31SAndrzej Bialecki } 160195ebc7eSPawel Jakub Dawidek return (error); 161bd3cdc31SAndrzej Bialecki } 162bd3cdc31SAndrzej Bialecki 163bd3cdc31SAndrzej Bialecki static moduledata_t mod_data = { 164bd3cdc31SAndrzej Bialecki "dyn_sysctl", 165bd3cdc31SAndrzej Bialecki load, 1669823d527SKevin Lo 0 167bd3cdc31SAndrzej Bialecki }; 168bd3cdc31SAndrzej Bialecki 169bd3cdc31SAndrzej Bialecki DECLARE_MODULE(dyn_sysctl, mod_data, SI_SUB_EXEC, SI_ORDER_ANY); 170