]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/dev/rtwn/pci/rtwn_pci_attach.h
MFV r336851:
[FreeBSD/FreeBSD.git] / sys / dev / rtwn / pci / rtwn_pci_attach.h
1 /*-
2  * Copyright (c) 2016 Andriy Voskoboinyk <avos@FreeBSD.org>
3  *
4  * Permission to use, copy, modify, and distribute this software for any
5  * purpose with or without fee is hereby granted, provided that the above
6  * copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15  * 
16  * $FreeBSD$
17  */
18
19 void    r92ce_attach(struct rtwn_pci_softc *);
20
21 enum {
22         RTWN_CHIP_RTL8192CE,
23         RTWN_CHIP_MAX_PCI
24 };
25
26 struct rtwn_pci_ident {
27         uint16_t        vendor;
28         uint16_t        device;
29         const char      *name;
30         int             chip;
31 };
32
33 static const struct rtwn_pci_ident rtwn_pci_ident_table[] = {
34         { 0x10ec, 0x8176, "Realtek RTL8188CE", RTWN_CHIP_RTL8192CE },
35         { 0, 0, NULL, RTWN_CHIP_MAX_PCI }
36 };
37
38 typedef void    (*chip_pci_attach)(struct rtwn_pci_softc *);
39
40 static const chip_pci_attach rtwn_chip_pci_attach[RTWN_CHIP_MAX_PCI] = {
41         [RTWN_CHIP_RTL8192CE] = r92ce_attach
42 };
43
44 static __inline void
45 rtwn_pci_attach_private(struct rtwn_pci_softc *pc, int chip)
46 {
47         rtwn_chip_pci_attach[chip](pc);
48 }