1 1.27 thorpej /* $NetBSD: obio.c,v 1.27 2021/08/07 16:18:57 thorpej Exp $ */ 2 1.1 briggs 3 1.1 briggs /* 4 1.5 scottr * Copyright (c) 1996 The NetBSD Foundation, Inc. 5 1.1 briggs * All rights reserved. 6 1.1 briggs * 7 1.5 scottr * This code is derived from software contributed to The NetBSD Foundation 8 1.5 scottr * by Jason R. Thorpe. 9 1.5 scottr * 10 1.1 briggs * Redistribution and use in source and binary forms, with or without 11 1.1 briggs * modification, are permitted provided that the following conditions 12 1.1 briggs * are met: 13 1.1 briggs * 1. Redistributions of source code must retain the above copyright 14 1.1 briggs * notice, this list of conditions and the following disclaimer. 15 1.1 briggs * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 briggs * notice, this list of conditions and the following disclaimer in the 17 1.1 briggs * documentation and/or other materials provided with the distribution. 18 1.1 briggs * 19 1.5 scottr * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.5 scottr * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.5 scottr * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.8 jtc * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.8 jtc * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.5 scottr * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.5 scottr * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.5 scottr * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.5 scottr * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.5 scottr * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.5 scottr * POSSIBILITY OF SUCH DAMAGE. 30 1.1 briggs */ 31 1.16 lukem 32 1.16 lukem #include <sys/cdefs.h> 33 1.27 thorpej __KERNEL_RCSID(0, "$NetBSD: obio.c,v 1.27 2021/08/07 16:18:57 thorpej Exp $"); 34 1.1 briggs 35 1.1 briggs #include <sys/param.h> 36 1.1 briggs #include <sys/systm.h> 37 1.1 briggs #include <sys/device.h> 38 1.1 briggs 39 1.17 chs #include "locators.h" 40 1.17 chs 41 1.11 briggs #include <machine/autoconf.h> 42 1.6 scottr 43 1.10 scottr #include <mac68k/obio/obiovar.h> 44 1.1 briggs 45 1.25 matt static int obio_match(device_t, cfdata_t, void *); 46 1.25 matt static void obio_attach(device_t, device_t, void *); 47 1.19 chs static int obio_print(void *, const char *); 48 1.25 matt static int obio_search(device_t, cfdata_t, const int *, void *); 49 1.1 briggs 50 1.25 matt CFATTACH_DECL_NEW(obio, 0, 51 1.14 thorpej obio_match, obio_attach, NULL, NULL); 52 1.1 briggs 53 1.1 briggs static int 54 1.25 matt obio_match(device_t parent, cfdata_t cf, void *aux) 55 1.1 briggs { 56 1.25 matt static bool obio_matched; 57 1.1 briggs 58 1.5 scottr /* Allow only one instance. */ 59 1.5 scottr if (obio_matched) 60 1.1 briggs return (0); 61 1.5 scottr 62 1.25 matt obio_matched = true; 63 1.5 scottr return (1); 64 1.1 briggs } 65 1.1 briggs 66 1.1 briggs static void 67 1.25 matt obio_attach(device_t parent, device_t self, void *aux) 68 1.1 briggs { 69 1.3 christos printf("\n"); 70 1.1 briggs 71 1.5 scottr /* Search for and attach children. */ 72 1.26 thorpej config_search(self, aux, 73 1.27 thorpej CFARGS(.search = obio_search)); 74 1.5 scottr } 75 1.5 scottr 76 1.5 scottr int 77 1.19 chs obio_print(void *args, const char *name) 78 1.5 scottr { 79 1.6 scottr struct obio_attach_args *oa = (struct obio_attach_args *)args; 80 1.5 scottr 81 1.6 scottr if (oa->oa_addr != (-1)) 82 1.15 thorpej aprint_normal(" addr %x", oa->oa_addr); 83 1.5 scottr 84 1.5 scottr return (UNCONF); 85 1.5 scottr } 86 1.5 scottr 87 1.5 scottr int 88 1.25 matt obio_search(device_t parent, cfdata_t cf, const int *ldesc, void *aux) 89 1.5 scottr { 90 1.11 briggs struct mainbus_attach_args *mba = (struct mainbus_attach_args *) aux; 91 1.5 scottr struct obio_attach_args oa; 92 1.5 scottr 93 1.20 chs oa.oa_addr = cf->cf_loc[OBIOCF_ADDR]; 94 1.11 briggs oa.oa_tag = mba->mba_bst; 95 1.11 briggs oa.oa_dmat = mba->mba_dmat; 96 1.6 scottr 97 1.26 thorpej if (config_probe(parent, cf, &oa)) 98 1.27 thorpej config_attach(parent, cf, &oa, obio_print, CFARGS_NONE); 99 1.6 scottr 100 1.5 scottr return (0); 101 1.1 briggs } 102