1 1.16 thorpej /* $NetBSD: shb.c,v 1.16 2021/08/07 16:19:05 thorpej Exp $ */ 2 1.1 uch 3 1.1 uch /*- 4 1.1 uch * Copyright (c) 2002 The NetBSD Foundation, Inc. 5 1.1 uch * All rights reserved. 6 1.1 uch * 7 1.1 uch * Redistribution and use in source and binary forms, with or without 8 1.1 uch * modification, are permitted provided that the following conditions 9 1.1 uch * are met: 10 1.1 uch * 1. Redistributions of source code must retain the above copyright 11 1.1 uch * notice, this list of conditions and the following disclaimer. 12 1.1 uch * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 uch * notice, this list of conditions and the following disclaimer in the 14 1.1 uch * documentation and/or other materials provided with the distribution. 15 1.1 uch * 16 1.1 uch * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.1 uch * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.1 uch * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.1 uch * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.1 uch * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.1 uch * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.1 uch * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.1 uch * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.1 uch * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.1 uch * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 uch * POSSIBILITY OF SUCH DAMAGE. 27 1.1 uch */ 28 1.7 lukem 29 1.7 lukem #include <sys/cdefs.h> 30 1.16 thorpej __KERNEL_RCSID(0, "$NetBSD: shb.c,v 1.16 2021/08/07 16:19:05 thorpej Exp $"); 31 1.1 uch 32 1.1 uch #include <sys/param.h> 33 1.1 uch #include <sys/systm.h> 34 1.1 uch #include <sys/device.h> 35 1.1 uch 36 1.1 uch #include <machine/autoconf.h> 37 1.1 uch 38 1.11 uwe extern struct cfdriver shb_cd; 39 1.11 uwe 40 1.12 uwe static int shb_match(device_t, cfdata_t, void *); 41 1.12 uwe static void shb_attach(device_t, device_t, void *); 42 1.11 uwe static int shb_print(void *, const char *); 43 1.12 uwe static int shb_search(device_t, cfdata_t, const int *, void *); 44 1.1 uch 45 1.12 uwe CFATTACH_DECL_NEW(shb, 0, 46 1.6 thorpej shb_match, shb_attach, NULL, NULL); 47 1.1 uch 48 1.11 uwe 49 1.11 uwe static int 50 1.12 uwe shb_match(device_t parent, cfdata_t cf, void *aux) 51 1.1 uch { 52 1.1 uch struct mainbus_attach_args *ma = aux; 53 1.1 uch 54 1.1 uch if (strcmp(ma->ma_name, shb_cd.cd_name) != 0) 55 1.1 uch return (0); 56 1.1 uch 57 1.1 uch return (1); 58 1.1 uch } 59 1.1 uch 60 1.11 uwe static void 61 1.12 uwe shb_attach(device_t parent, device_t self, void *aux) 62 1.1 uch { 63 1.1 uch 64 1.12 uwe aprint_naive("\n"); 65 1.12 uwe aprint_normal("\n"); 66 1.2 uch 67 1.15 thorpej config_search(self, NULL, 68 1.16 thorpej CFARGS(.search = shb_search)); 69 1.14 uwe 70 1.14 uwe /* 71 1.14 uwe * XXX: TODO: provide hooks to manage on-chip modules. For 72 1.14 uwe * now register null hooks which is no worse than before. 73 1.14 uwe */ 74 1.14 uwe if (!pmf_device_register(self, NULL, NULL)) 75 1.14 uwe aprint_error_dev(self, "unable to establish power handler\n"); 76 1.1 uch } 77 1.1 uch 78 1.11 uwe static int 79 1.12 uwe shb_search(device_t parent, cfdata_t cf, const int *ldesc, void *aux) 80 1.1 uch { 81 1.1 uch 82 1.15 thorpej if (config_probe(parent, cf, NULL)) 83 1.16 thorpej config_attach(parent, cf, NULL, shb_print, CFARGS_NONE); 84 1.1 uch 85 1.1 uch return (0); 86 1.1 uch } 87 1.1 uch 88 1.11 uwe static int 89 1.1 uch shb_print(void *aux, const char *pnp) 90 1.1 uch { 91 1.1 uch 92 1.1 uch return (pnp ? QUIET : UNCONF); 93 1.1 uch } 94