1a9643ea8Slogwang /*- 2*22ce4affSfengbojiang * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 3*22ce4affSfengbojiang * 4a9643ea8Slogwang * Copyright (c) 2010 Lawrence Stewart <[email protected]> 5a9643ea8Slogwang * Copyright (c) 2010 The FreeBSD Foundation 6a9643ea8Slogwang * All rights reserved. 7a9643ea8Slogwang * 8a9643ea8Slogwang * This software was developed by Lawrence Stewart while studying at the Centre 9a9643ea8Slogwang * for Advanced Internet Architectures, Swinburne University of Technology, made 10a9643ea8Slogwang * possible in part by grants from the FreeBSD Foundation and Cisco University 11a9643ea8Slogwang * Research Program Fund at Community Foundation Silicon Valley. 12a9643ea8Slogwang * 13a9643ea8Slogwang * Portions of this software were developed at the Centre for Advanced 14a9643ea8Slogwang * Internet Architectures, Swinburne University of Technology, Melbourne, 15a9643ea8Slogwang * Australia by Lawrence Stewart under sponsorship from the FreeBSD Foundation. 16a9643ea8Slogwang * 17a9643ea8Slogwang * Redistribution and use in source and binary forms, with or without 18a9643ea8Slogwang * modification, are permitted provided that the following conditions 19a9643ea8Slogwang * are met: 20a9643ea8Slogwang * 1. Redistributions of source code must retain the above copyright 21a9643ea8Slogwang * notice, this list of conditions and the following disclaimer. 22a9643ea8Slogwang * 2. Redistributions in binary form must reproduce the above copyright 23a9643ea8Slogwang * notice, this list of conditions and the following disclaimer in the 24a9643ea8Slogwang * documentation and/or other materials provided with the distribution. 25a9643ea8Slogwang * 26a9643ea8Slogwang * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 27a9643ea8Slogwang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 28a9643ea8Slogwang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 29a9643ea8Slogwang * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 30a9643ea8Slogwang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 31a9643ea8Slogwang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 32a9643ea8Slogwang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 33a9643ea8Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 34a9643ea8Slogwang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 35a9643ea8Slogwang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 36a9643ea8Slogwang * SUCH DAMAGE. 37a9643ea8Slogwang * 38a9643ea8Slogwang * $FreeBSD$ 39a9643ea8Slogwang */ 40a9643ea8Slogwang 41a9643ea8Slogwang #ifndef _SYS_MODULE_KHELP_H_ 42a9643ea8Slogwang #define _SYS_MODULE_KHELP_H_ 43a9643ea8Slogwang 44a9643ea8Slogwang /* XXXLAS: Needed for uma related typedefs. */ 45a9643ea8Slogwang #include <vm/uma.h> 46a9643ea8Slogwang 47a9643ea8Slogwang /* Helper flags. */ 48a9643ea8Slogwang #define HELPER_NEEDS_OSD 0x0001 49a9643ea8Slogwang 50a9643ea8Slogwang struct helper { 51a9643ea8Slogwang int (*mod_init) (void); 52a9643ea8Slogwang int (*mod_destroy) (void); 53a9643ea8Slogwang #define HELPER_NAME_MAXLEN 16 54a9643ea8Slogwang char h_name[HELPER_NAME_MAXLEN]; 55a9643ea8Slogwang uma_zone_t h_zone; 56a9643ea8Slogwang struct hookinfo *h_hooks; 57a9643ea8Slogwang uint32_t h_nhooks; 58a9643ea8Slogwang uint32_t h_classes; 59a9643ea8Slogwang int32_t h_id; 60a9643ea8Slogwang volatile uint32_t h_refcount; 61a9643ea8Slogwang uint16_t h_flags; 62a9643ea8Slogwang TAILQ_ENTRY(helper) h_next; 63a9643ea8Slogwang }; 64a9643ea8Slogwang 65a9643ea8Slogwang struct khelp_modevent_data { 66a9643ea8Slogwang char name[HELPER_NAME_MAXLEN]; 67a9643ea8Slogwang struct helper *helper; 68a9643ea8Slogwang struct hookinfo *hooks; 69a9643ea8Slogwang int nhooks; 70a9643ea8Slogwang int uma_zsize; 71a9643ea8Slogwang uma_ctor umactor; 72a9643ea8Slogwang uma_dtor umadtor; 73a9643ea8Slogwang }; 74a9643ea8Slogwang 75a9643ea8Slogwang #define KHELP_DECLARE_MOD_UMA(hname, hdata, hhooks, version, size, ctor, dtor) \ 76a9643ea8Slogwang static struct khelp_modevent_data kmd_##hname = { \ 77a9643ea8Slogwang .name = #hname, \ 78a9643ea8Slogwang .helper = hdata, \ 79a9643ea8Slogwang .hooks = hhooks, \ 80a9643ea8Slogwang .nhooks = sizeof(hhooks) / sizeof(hhooks[0]), \ 81a9643ea8Slogwang .uma_zsize = size, \ 82a9643ea8Slogwang .umactor = ctor, \ 83a9643ea8Slogwang .umadtor = dtor \ 84a9643ea8Slogwang }; \ 85a9643ea8Slogwang static moduledata_t h_##hname = { \ 86a9643ea8Slogwang .name = #hname, \ 87a9643ea8Slogwang .evhand = khelp_modevent, \ 88a9643ea8Slogwang .priv = &kmd_##hname \ 89a9643ea8Slogwang }; \ 90a9643ea8Slogwang DECLARE_MODULE(hname, h_##hname, SI_SUB_KLD, SI_ORDER_ANY); \ 91a9643ea8Slogwang MODULE_VERSION(hname, version) 92a9643ea8Slogwang 93a9643ea8Slogwang #define KHELP_DECLARE_MOD(hname, hdata, hhooks, version) \ 94a9643ea8Slogwang KHELP_DECLARE_MOD_UMA(hname, hdata, hhooks, version, 0, NULL, NULL) 95a9643ea8Slogwang 96a9643ea8Slogwang int khelp_modevent(module_t mod, int type, void *data); 97a9643ea8Slogwang 98a9643ea8Slogwang #endif /* _SYS_MODULE_KHELP_H_ */ 99