1 | /*␊ |
2 | * Copyright (c) 2009 Evan Lojewski. All rights reserved.␊ |
3 | *␊ |
4 | * Merge into file from module compcept by ErmaC and Marchrius ␊ |
5 | *␊ |
6 | */␊ |
7 | ␊ |
8 | #include "boot.h"␊ |
9 | #include "bootstruct.h"␊ |
10 | #include "pci.h"␊ |
11 | #include "platform.h"␊ |
12 | #include "device_inject.h"␊ |
13 | #include "networking.h"␊ |
14 | ␊ |
15 | #ifndef DEBUG_NETWORKING␊ |
16 | ␉#define DEBUG_NETWORKING 0␊ |
17 | #endif␊ |
18 | ␊ |
19 | #if DEBUG_NETWORKING␊ |
20 | ␉#define DBG(x...)␉printf(x)␊ |
21 | #else␊ |
22 | ␉#define DBG(x...)␊ |
23 | #endif␊ |
24 | ␊ |
25 | uint32_t builtin_set␉= 0;␊ |
26 | uint8_t builtin␉␉= 0;␊ |
27 | extern uint32_t devices_number;␊ |
28 | //extern uint32_t onboard_number;␊ |
29 | ␊ |
30 | int devprop_add_network_template(DevPropDevice *device, uint16_t vendor_id)␊ |
31 | {␊ |
32 | ␉builtin = 0;␊ |
33 | ␉if(device)␊ |
34 | ␉{␊ |
35 | ␊ |
36 | ␉␉if((vendor_id != PCI_VENDOR_ID_ATHEROS) && (builtin_set == 0))␊ |
37 | ␉␉{␊ |
38 | ␉␉␉builtin_set = 1;␊ |
39 | ␉␉␉builtin = 0x01;␊ |
40 | ␉␉}␊ |
41 | ␊ |
42 | ␉␉if(!devprop_add_value(device, "built-in", (uint8_t *)&builtin, 1))␊ |
43 | ␉␉{␊ |
44 | ␉␉␉return 0;␊ |
45 | ␉␉}␊ |
46 | ␊ |
47 | ␉␉if(!devprop_add_value(device, "device_type", (uint8_t *)"ethernet", sizeof("ethernet")))␊ |
48 | ␉␉{␊ |
49 | ␉␉␉return 0;␊ |
50 | ␉␉}␊ |
51 | ␊ |
52 | ␉␉devices_number++;␊ |
53 | ␉␉return 1;␊ |
54 | ␉}␊ |
55 | ␉else␊ |
56 | ␉{␊ |
57 | ␉␉return 0;␊ |
58 | ␉}␊ |
59 | }␊ |
60 | ␊ |
61 | static network_device known_ethernet_cards[] =␊ |
62 | {␊ |
63 | ␊ |
64 | ␉// Realtek␊ |
65 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8129, "Realtek 8129 Gigabit Ethernet" },␊ |
66 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8136, "Realtek RTL8101E/RTL8102E PCI-E Fast Ethernet Controller" },␊ |
67 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8139, "Realtek RTL8139/810x Family Fast Ethernet" },␊ |
68 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8167, "Realtek 8169/8110 Gigabit Ethernet" },␊ |
69 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8168, "Realtek RTL8111/8168 PCI-E Gigabit Ethernet" },␊ |
70 | ␉{ PCI_VENDOR_ID_REALTEK, 0x8169, "Realtek 8169/8110 Gigabit Ethernet" },␊ |
71 | ␊ |
72 | ␉{ 0x1113, 0x1211, "Realtek RTL8139 Family Fast Ethernet" },␊ |
73 | ␉{ 0x1500, 0x1360, "Realtek RTL8139 Family Fast Ethernet" },␊ |
74 | ␉{ 0x4033, 0x1360, "Realtek RTL8139 Family Fast Ethernet" },␊ |
75 | ␉{ 0x1186, 0x1300, "Realtek RTL8139 Family Fast Ethernet" },␊ |
76 | ␉{ 0x1186, 0x1340, "Realtek RTL8139 Family Fast Ethernet" },␊ |
77 | ␉{ 0x13d1, 0xab06, "Realtek RTL8139 Family Fast Ethernet" },␊ |
78 | ␉{ 0x1259, 0xa117, "Realtek RTL8139 Family Fast Ethernet" },␊ |
79 | ␉{ 0x1259, 0xa11e, "Realtek RTL8139 Family Fast Ethernet" },␊ |
80 | ␉{ 0x14ea, 0xab06, "Realtek RTL8139 Family Fast Ethernet" },␊ |
81 | ␉{ 0x14ea, 0xab07, "Realtek RTL8139 Family Fast Ethernet" },␊ |
82 | ␉{ 0x11db, 0x1234, "Realtek RTL8139 Family Fast Ethernet" },␊ |
83 | ␉{ 0x1432, 0x9130, "Realtek RTL8139 Family Fast Ethernet" },␊ |
84 | ␉{ 0x02ac, 0x1012, "Realtek RTL8139 Family Fast Ethernet" },␊ |
85 | ␉{ 0x018a, 0x0106, "Realtek RTL8139 Family Fast Ethernet" },␊ |
86 | ␉{ 0x126c, 0x1211, "Realtek RTL8139 Family Fast Ethernet" },␊ |
87 | ␉{ 0x1743, 0x8139, "Realtek RTL8139 Family Fast Ethernet" },␊ |
88 | ␉{ 0x021b, 0x8139, "Realtek RTL8139 Family Fast Ethernet" },␊ |
89 | ␊ |
90 | ␉// Marvell␊ |
91 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4320, "Marvell 88E8001 Gigabit Ethernet Controller" },␊ |
92 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4340, "Marvell 88E8021 PCI-X IPMI Gigabit Ethernet Controller" },␊ |
93 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4341, "Marvell 88E8022 PCI-X IPMI Gigabit Ethernet Controller" },␊ |
94 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4342, "Marvell 88E8061 PCI-E IPMI Gigabit Ethernet Controller" },␊ |
95 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4343, "Marvell 88E8062 PCI-E IPMI Gigabit Ethernet Controller" },␊ |
96 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4344, "Marvell 88E8021 PCI-X IPMI Gigabit Ethernet Controller" },␊ |
97 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4345, "Marvell 88E8022 PCI-X IPMI Gigabit Ethernet Controller" },␊ |
98 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4346, "Marvell 88E8061 PCI-E IPMI Gigabit Ethernet Controller" },␊ |
99 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4347, "Marvell 88E8062 PCI-E IPMI Gigabit Ethernet Controller" },␊ |
100 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4350, "Marvell 88E8035 PCI-E Fast Ethernet Controller" },␊ |
101 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4351, "Marvell 88E8036 PCI-E Fast Ethernet Controller" },␊ |
102 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4352, "Marvell 88E8038 PCI-E Fast Ethernet Controller" },␊ |
103 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4353, "Marvell 88E8039 PCI-E Fast Ethernet Controller" },␊ |
104 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4354, "Marvell 88E8040 PCI-E Fast Ethernet Controller" },␊ |
105 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4355, "Marvell 88E8040T PCI-E Fast Ethernet Controller" },␊ |
106 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4356, "Marvell 88EC033 PCI-E Fast Ethernet Controller" },␊ |
107 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4357, "Marvell 88E8042 PCI-E Fast Ethernet Controller" },␊ |
108 | ␉{ PCI_VENDOR_ID_MARVELL, 0x435A, "Marvell 88E8048 PCI-E Fast Ethernet Controller" },␊ |
109 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4360, "Marvell 88E8052 PCI-E ASF Gigabit Ethernet Controller" },␊ |
110 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4361, "Marvell 88E8050 PCI-E ASF Gigabit Ethernet Controller" },␊ |
111 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4362, "Marvell 88E8053 PCI-E Gigabit Ethernet Controller" },␊ |
112 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4363, "Marvell 88E8055 PCI-E Gigabit Ethernet Controller" },␊ |
113 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4364, "Marvell 88E8056 PCI-E Gigabit Ethernet Controller" },␊ |
114 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4365, "Marvell 8E8070 based Ethernet Controller" },␊ |
115 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4366, "Marvell 88EC036 PCI-E Gigabit Ethernet Controller" },␊ |
116 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4367, "Marvell 88EC032 Ethernet Controller" },␊ |
117 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4368, "Marvell 88EC034 Ethernet Controller" },␊ |
118 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4369, "Marvell 88EC042 Ethernet Controller" },␊ |
119 | ␉{ PCI_VENDOR_ID_MARVELL, 0x436A, "Marvell 88E8058 PCI-E Gigabit Ethernet Controller" },␊ |
120 | ␉{ PCI_VENDOR_ID_MARVELL, 0x436B, "Marvell 88E8071 PCI-E Gigabit Ethernet Controller" },␊ |
121 | ␉{ PCI_VENDOR_ID_MARVELL, 0x436C, "Marvell 88E8072 PCI-E Gigabit Ethernet Controller" },␊ |
122 | ␉{ PCI_VENDOR_ID_MARVELL, 0x436D, "Marvell 88E8055 PCI-E Gigabit Ethernet Controller" },␊ |
123 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4370, "Marvell 88E8075 PCI-E Gigabit Ethernet Controller" },␊ |
124 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4380, "Marvell 88E8057 PCI-E Gigabit Ethernet Controller" },␊ |
125 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4381, "Marvell 88E8059 PCI-E Gigabit Ethernet Controller" },␊ |
126 | ␉{ PCI_VENDOR_ID_MARVELL, 0x4382, "Marvell 88E8079 PCI-E Gigabit Ethernet Controller" },␊ |
127 | //␉{ PCI_VENDOR_ID_MARVELL, 0x5005, "Belkin F5D5005 Gigabit Desktop Network PCI Card" },␊ |
128 | ␊ |
129 | ␉// Broadcom␊ |
130 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1600, "Broadcom BCM5752 Gigabit Ethernet PCI Express" },␊ |
131 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1655, "Broadcom BCM5717 Gigabit Ethernet PCIe" },␊ |
132 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1656, "Broadcom BCM5718 Gigabit Ethernet PCIe" },␊ |
133 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1657, "Broadcom BCM5719 Gigabit Ethernet PCIe" },␊ |
134 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1659, "Broadcom BCM5721 Gigabit Ethernet PCI Express" },␊ |
135 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x165A, "Broadcom BCM5722 Gigabit Ethernet PCI Express" },␊ |
136 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x166A, "Broadcom BCM5780 Gigabit Ethernet" },␊ |
137 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1672, "Broadcom BCM5754M Gigabit Ethernet PCI Express" },␊ |
138 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1673, "Broadcom BCM5755M Gigabit Ethernet PCI Express" },␊ |
139 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x167A, "Broadcom BCM5754 Gigabit Ethernet PCI Express" },␊ |
140 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x167B, "Broadcom BCM5755 Gigabit Ethernet PCI Express" },␊ |
141 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1684, "Broadcom BCM5764M Gigabit Ethernet PCIe" },␊ |
142 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1691, "Broadcom BCM57788 Gigabit Ethernet PCIe" },␊ |
143 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1693, "Broadcom BCM5787M Gigabit Ethernet PCI Express" },␊ |
144 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x169B, "Broadcom BCM5787 Gigabit Ethernet PCI Express" },␊ |
145 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x16B4, "Broadcom BCM57765 Gigabit Ethernet PCIe" },␊ |
146 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x16B5, "Broadcom BCM57785 Gigabit Ethernet PCIe" },␊ |
147 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1712, "Broadcom BCM5906 Fast Ethernet PCI Express" },␊ |
148 | ␉{ PCI_VENDOR_ID_BROADCOM, 0x1713, "Broadcom BCM5906M Fast Ethernet PCI Express" },␊ |
149 | ␊ |
150 | ␉// JMicron␊ |
151 | ␉{ PCI_VENDOR_ID_JMICRON, 0x0250, "JMicron JMC250 PCI Express Gigabit Ethernet Controller" },␊ |
152 | ␉{ PCI_VENDOR_ID_JMICRON, 0x0260, "JMicron JMC260 PCI Express Gigabit Ethernet Controller" },␊ |
153 | ␊ |
154 | ␉// Intel␊ |
155 | //␉{ PCI_VENDOR_ID_INTEL, 0x1000, "Intel 82542 Gigabit Ethernet Controller (Fiber)" },␊ |
156 | ␉{ PCI_VENDOR_ID_INTEL, 0x1029, "Intel 8255x Ethernet" },␊ |
157 | ␉{ PCI_VENDOR_ID_INTEL, 0x1030, "Intel 8255x Ethernet" },␊ |
158 | ␉{ PCI_VENDOR_ID_INTEL, 0x1031, "Intel 8255x Ethernet" },␊ |
159 | ␉{ PCI_VENDOR_ID_INTEL, 0x1032, "Intel 8255x Ethernet" },␊ |
160 | ␉{ PCI_VENDOR_ID_INTEL, 0x1033, "Intel 8255x Ethernet" },␊ |
161 | ␉{ PCI_VENDOR_ID_INTEL, 0x1034, "Intel 8255x Ethernet" },␊ |
162 | ␉{ PCI_VENDOR_ID_INTEL, 0x1038, "Intel 8255x Ethernet" },␊ |
163 | ␉{ PCI_VENDOR_ID_INTEL, 0x1039, "Intel 8255x Ethernet" },␊ |
164 | ␉{ PCI_VENDOR_ID_INTEL, 0x103A, "Intel 8255x Ethernet" },␊ |
165 | ␉{ PCI_VENDOR_ID_INTEL, 0x103B, "Intel 8255x Ethernet" },␊ |
166 | ␉{ PCI_VENDOR_ID_INTEL, 0x103C, "Intel 8255x Ethernet" },␊ |
167 | ␉{ PCI_VENDOR_ID_INTEL, 0x103D, "Intel 8255x Ethernet" },␊ |
168 | ␉{ PCI_VENDOR_ID_INTEL, 0x103E, "Intel 8255x Ethernet" },␊ |
169 | //␉{ PCI_VENDOR_ID_INTEL, 0x1049, "Intel 82566MM Gigabit Network Connection" },␊ |
170 | //␉{ PCI_VENDOR_ID_INTEL, 0x104A, "Intel 82566DM Gigabit Network Connection" },␊ |
171 | //␉{ PCI_VENDOR_ID_INTEL, 0x104B, "Intel 82566DC Gigabit Network Connection" },␊ |
172 | //␉{ PCI_VENDOR_ID_INTEL, 0x104C, "Intel 82562V 10/100 Network Connection" },␊ |
173 | //␉{ PCI_VENDOR_ID_INTEL, 0x104D, "Intel 82566MC Gigabit Network Connection" },␊ |
174 | ␉{ PCI_VENDOR_ID_INTEL, 0x1050, "Intel 82562EZ 10/100 Ethernet Controller" },␊ |
175 | ␉{ PCI_VENDOR_ID_INTEL, 0x1051, "Intel 82801EB/ER (ICH5/ICH5R) integrated LAN Controller" },␊ |
176 | ␉{ PCI_VENDOR_ID_INTEL, 0x1052, "Intel PRO/100 VE Network Connection" },␊ |
177 | ␉{ PCI_VENDOR_ID_INTEL, 0x1053, "Intel PRO/100 VE Network Connection" },␊ |
178 | ␉{ PCI_VENDOR_ID_INTEL, 0x1054, "Intel PRO/100 VE Network Connection" },␊ |
179 | ␉{ PCI_VENDOR_ID_INTEL, 0x1055, "Intel PRO/100 VE Network Connection" },␊ |
180 | ␉{ PCI_VENDOR_ID_INTEL, 0x1056, "Intel PRO/100 VE Network Connection" },␊ |
181 | ␉{ PCI_VENDOR_ID_INTEL, 0x1057, "Intel PRO/100 VE Network Connection" },␊ |
182 | ␉{ PCI_VENDOR_ID_INTEL, 0x1059, "Intel 82551QM Ethernet Controller" },␊ |
183 | //␉{ PCI_VENDOR_ID_INTEL, 0x105b "Intel 82546GB Gigabit Ethernet Controller (Copper)" },␊ |
184 | //␉{ PCI_VENDOR_ID_INTEL, 0x105E, "Intel 82546GB Gigabit Ethernet Controller" },␊ |
185 | //␉{ PCI_VENDOR_ID_INTEL, 0x105F, "Intel 82571EB Gigabit Ethernet Controller" },␊ |
186 | ␉{ PCI_VENDOR_ID_INTEL, 0x1060, "Intel 82571EB Gigabit Ethernet Controller" },␊ |
187 | ␉{ PCI_VENDOR_ID_INTEL, 0x1064, "Intel 82562ET/EZ/GT/GZ - PRO/100 VE (LOM) Ethernet Controller" },␊ |
188 | ␉{ PCI_VENDOR_ID_INTEL, 0x1065, "Intel 82562ET/EZ/GT/GZ - PRO/100 VE Ethernet Controller" },␊ |
189 | ␉{ PCI_VENDOR_ID_INTEL, 0x1066, "Intel 82562 EM/EX/GX - PRO/100 VM (LOM) Ethernet Controller" },␊ |
190 | ␉{ PCI_VENDOR_ID_INTEL, 0x1067, "Intel 82562 EM/EX/GX - PRO/100 VM Ethernet Controller" },␊ |
191 | ␉{ PCI_VENDOR_ID_INTEL, 0x1068, "Intel 82562ET/EZ/GT/GZ - PRO/100 VE (LOM) Ethernet Controller Mobile" },␊ |
192 | ␉{ PCI_VENDOR_ID_INTEL, 0x1069, "Intel 82562EM/EX/GX - PRO/100 VM (LOM) Ethernet Controller Mobile" },␊ |
193 | ␉{ PCI_VENDOR_ID_INTEL, 0x106A, "Intel 82562G - PRO/100 VE (LOM) Ethernet Controller" },␊ |
194 | ␉{ PCI_VENDOR_ID_INTEL, 0x106B, "Intel 82562G - PRO/100 VE Ethernet Controller Mobile" },␊ |
195 | ␉{ PCI_VENDOR_ID_INTEL, 0x1075, "82547GI Gigabit Ethernet Controller" },␊ |
196 | ␉{ PCI_VENDOR_ID_INTEL, 0x1076, "82541GI Gigabit Ethernet Controller" },␊ |
197 | ␉{ PCI_VENDOR_ID_INTEL, 0x1077, "82541GI Gigabit Ethernet Controller" },␊ |
198 | ␉{ PCI_VENDOR_ID_INTEL, 0x1078, "82541ER Gigabit Ethernet Controller" },␊ |
199 | ␉{ PCI_VENDOR_ID_INTEL, 0x1079, "82546GB Gigabit Ethernet Controller" },␊ |
200 | ␉{ PCI_VENDOR_ID_INTEL, 0x107a, "82546GB Gigabit Ethernet Controller" },␊ |
201 | ␉{ PCI_VENDOR_ID_INTEL, 0x107b, "82546GB Gigabit Ethernet Controller" },␊ |
202 | ␉{ PCI_VENDOR_ID_INTEL, 0x107c, "82541PI Gigabit Ethernet Controller" },␊ |
203 | //␉{ PCI_VENDOR_ID_INTEL, 0x107D, "Intel 82572EI Gigabit Ethernet Controller (Copper)" },␊ |
204 | //␉{ PCI_VENDOR_ID_INTEL, 0x107E, "Intel 82572EI Gigabit Ethernet Controller (Fiber)" },␊ |
205 | //␉{ PCI_VENDOR_ID_INTEL, 0x107F, "Intel 82572EI Gigabit Ethernet Controller" },␊ |
206 | //␉{ PCI_VENDOR_ID_INTEL, 0x108a, "Intel 82546GB Gigabit Ethernet Controller" },␊ |
207 | //␉{ PCI_VENDOR_ID_INTEL, 0x108B, "Intel 82573V Gigabit Ethernet Controller (Copper)" },␊ |
208 | //␉{ PCI_VENDOR_ID_INTEL, 0x108C, "Intel 82573E Gigabit Ethernet Controller (Copper)" },␊ |
209 | ␉{ PCI_VENDOR_ID_INTEL, 0x1091, "Intel PRO/100 VM Network Connection" },␊ |
210 | ␉{ PCI_VENDOR_ID_INTEL, 0x1092, "Intel PRO/100 VE Network Connection" },␊ |
211 | ␉{ PCI_VENDOR_ID_INTEL, 0x1093, "Intel PRO/100 VM Network Connection" },␊ |
212 | ␉{ PCI_VENDOR_ID_INTEL, 0x1094, "Intel PRO/100 VE Network Connection" },␊ |
213 | ␉{ PCI_VENDOR_ID_INTEL, 0x1095, "Intel PRO/100 VE Network Connection" },␊ |
214 | //␉{ PCI_VENDOR_ID_INTEL, 0x1096, "Intel 80003ES2LAN Gigabit Ethernet Controller (Copper)" },␊ |
215 | //␉{ PCI_VENDOR_ID_INTEL, 0x1098, "Intel 80003ES2LAN Gigabit Ethernet Controller (Serdes)" },␊ |
216 | //␉{ PCI_VENDOR_ID_INTEL, 0x109A, "Intel 82573L Gigabit Ethernet Controller" },␊ |
217 | //␉{ PCI_VENDOR_ID_INTEL, 0x10A4, "Intel 82571EB Gigabit Ethernet Controller" },␊ |
218 | //␉{ PCI_VENDOR_ID_INTEL, 0x10A5, "Intel 82571EB Gigabit Ethernet Controller (Fiber)" },␊ |
219 | //␉{ PCI_VENDOR_ID_INTEL, 0x10BA, "Intel " },␊ |
220 | //␉{ PCI_VENDOR_ID_INTEL, 0x10BC, "Intel " },␊ |
221 | //␉{ PCI_VENDOR_ID_INTEL, 0x10B9, "Intel " },␊ |
222 | //␉{ PCI_VENDOR_ID_INTEL, 0x10BB, "Intel " },␊ |
223 | //␉{ PCI_VENDOR_ID_INTEL, 0x10BD, "Intel " },␊ |
224 | //␉{ PCI_VENDOR_ID_INTEL, 0x10BF, "Intel " },␊ |
225 | //␉{ PCI_VENDOR_ID_INTEL, 0x10C0, "Intel " },␊ |
226 | //␉{ PCI_VENDOR_ID_INTEL, 0x10C2, "Intel " },␊ |
227 | //␉{ PCI_VENDOR_ID_INTEL, 0x10C3, "Intel " },␊ |
228 | //␉{ PCI_VENDOR_ID_INTEL, 0x10C4, "Intel " },␊ |
229 | //␉{ PCI_VENDOR_ID_INTEL, 0x10C5, "Intel " },␊ |
230 | //␉{ PCI_VENDOR_ID_INTEL, 0x10CB, "Intel " },␊ |
231 | //␉{ PCI_VENDOR_ID_INTEL, 0x10CC, "Intel " },␊ |
232 | //␉{ PCI_VENDOR_ID_INTEL, 0x10CD, "Intel " },␊ |
233 | ␉{ PCI_VENDOR_ID_INTEL, 0x10CE, "Intel 82567V-2 Gigabit Network Connection" },␊ |
234 | ␉{ PCI_VENDOR_ID_INTEL, 0x10D3, "Intel 82574L Gigabit Network Connection" },␊ |
235 | //␉{ PCI_VENDOR_ID_INTEL, 0x10D5, "Intel " },␊ |
236 | ␉{ PCI_VENDOR_ID_INTEL, 0x10d6, "Intel 82575GB Gigabit Network Connection" },␊ |
237 | //␉{ PCI_VENDOR_ID_INTEL, 0x10D9, "Intel " },␊ |
238 | //␉{ PCI_VENDOR_ID_INTEL, 0x10DA, "Intel " },␊ |
239 | //␉{ PCI_VENDOR_ID_INTEL, 0x10DE, "Intel " },␊ |
240 | //␉{ PCI_VENDOR_ID_INTEL, 0x10DF, "Intel " },␊ |
241 | //␉{ PCI_VENDOR_ID_INTEL, 0x10E5, "Intel " },␊ |
242 | //␉{ PCI_VENDOR_ID_INTEL, 0x10EA, "Intel " },␊ |
243 | //␉{ PCI_VENDOR_ID_INTEL, 0x10EB, "Intel " },␊ |
244 | //␉{ PCI_VENDOR_ID_INTEL, 0x10EF, "Intel " },␊ |
245 | //␉{ PCI_VENDOR_ID_INTEL, 0x10F5, "Intel " },␊ |
246 | //␉{ PCI_VENDOR_ID_INTEL, 0x10F6, "Intel " },␊ |
247 | ␉{ PCI_VENDOR_ID_INTEL, 0x10F0, "Intel 82578DC Gigabit Network Connection" },␊ |
248 | ␉{ PCI_VENDOR_ID_INTEL, 0x10FE, "Intel 82552 10/100 Network Connection" },␊ |
249 | ␉{ PCI_VENDOR_ID_INTEL, 0x1209, "Intel 8255xER/82551IT Fast Ethernet Controller" },␊ |
250 | ␉{ PCI_VENDOR_ID_INTEL, 0x1227, "Intel 82865 EtherExpress PRO/100A" },␊ |
251 | ␉{ PCI_VENDOR_ID_INTEL, 0x1228, "Intel 82556 EtherExpress PRO/100 Smart" },␊ |
252 | ␉{ PCI_VENDOR_ID_INTEL, 0x1229, "Intel 82557/8/9/0/1 Ethernet Pro 100" },␊ |
253 | //␉{ PCI_VENDOR_ID_INTEL, 0x1501, "Intel 82567V-3 Gigabit Network Connection" },␊ |
254 | ␉{ PCI_VENDOR_ID_INTEL, 0x1502, "Intel 82579LM Gigabit Network Connection" },␊ |
255 | ␉{ PCI_VENDOR_ID_INTEL, 0x1503, "Intel 82579V Gigabit Network Controller" },␊ |
256 | //␉{ PCI_VENDOR_ID_INTEL, 0x150C, "Intel 82583V Gigabit Network Connection" },␊ |
257 | //␉{ PCI_VENDOR_ID_INTEL, 0x1525, "Intel 82567V-4 Gigabit Network Connection" },␊ |
258 | ␉{ PCI_VENDOR_ID_INTEL, 0x153A, "Intel Ethernet Connection I217-LM" },␊ |
259 | ␉{ PCI_VENDOR_ID_INTEL, 0x153B, "Intel Ethernet Connection I217-V" },␊ |
260 | ␉{ PCI_VENDOR_ID_INTEL, 0x1559, "Intel Ethernet Connection I218-V" },␊ |
261 | ␉{ PCI_VENDOR_ID_INTEL, 0x155A, "Intel Ethernet Connection I218-LM" },␊ |
262 | ␉{ PCI_VENDOR_ID_INTEL, 0x15A0, "Intel Ethernet Connection (2) I218-LM" },␊ |
263 | ␉{ PCI_VENDOR_ID_INTEL, 0x15A1, "Intel Ethernet Connection (2) I218-V" },␊ |
264 | ␉{ PCI_VENDOR_ID_INTEL, 0x15A2, "Intel Ethernet Connection (3) I218-LM" },␊ |
265 | ␉{ PCI_VENDOR_ID_INTEL, 0x15A3, "Intel Ethernet Connection (3) I218-V" },␊ |
266 | ␉{ PCI_VENDOR_ID_INTEL, 0x2449, "Intel 82801BA/BAM/CA/CAM Ethernet Controller" },␊ |
267 | ␉{ PCI_VENDOR_ID_INTEL, 0x2459, "Intel 82801E Ethernet Controller" },␊ |
268 | ␉{ PCI_VENDOR_ID_INTEL, 0x245D, "Intel 82801E Ethernet Controller" },␊ |
269 | ␉{ PCI_VENDOR_ID_INTEL, 0x27DC, "Intel NM10/ICH7 Family LAN Controller" },␊ |
270 | //␉{ PCI_VENDOR_ID_INTEL, 0x294C, "Intel 82566DC-2 Gigabit Network Connection" },␊ |
271 | ␊ |
272 | //␉Atheros (Qualcomm)␊ |
273 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1026, "Atheros AR8121/AR8113/AR8114 Ethernet" },␊ |
274 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1062, "Atheros AR8132 Fast Ethernet" },␊ |
275 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1063, "Atheros AR8131 Gigabit Ethernet" },␊ |
276 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1066, "Atheros AR8121/AR8113/AR8114 Ethernet" },␊ |
277 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1067, "Atheros L1c Gigabit Ethernet" },␊ |
278 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1073, "Atheros AR8151 v1.0 Gigabit 1000" },␊ |
279 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1083, "Atheros GbE LAN chip (10/100/1000 Mbit)" },␊ |
280 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1090, "Atheros AR8162 Fast Ethernet" },␊ |
281 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x1091, "Atheros AR8161 Gigabit Ethernet" },␊ |
282 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x10a0, "Atheros QCA8172 Fast Ethernet" },␊ |
283 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x10a1, "Atheros QCA8171 Gigabit Ethernet" },␊ |
284 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x2048, "Atheros L2 Fast Ethernet" },␊ |
285 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x2060, "Atheros AR8152 v1.1 Fast 10/100" },␊ |
286 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x2062, "Atheros AR8152 v2.0 Fast 10/100" },␊ |
287 | ␊ |
288 | };␊ |
289 | ␊ |
290 | static network_device generic_ethernet_cards[] =␊ |
291 | {␊ |
292 | ␉{ 0x0000, 0x0000, "Generic Ethernet Controller" },␊ |
293 | ␉{ PCI_VENDOR_ID_REALTEK, 0x0000, "Realtek Ethernet Controller" },␊ |
294 | ␉{ PCI_VENDOR_ID_MARVELL, 0x0000, "Marvell Ethernet Controller" },␊ |
295 | ␉{ PCI_VENDOR_ID_QUALCOMM, 0x0000, "Atheros Ethernet Controller" },␊ |
296 | ␉{ PCI_VENDOR_ID_INTEL, 0x0000, "Intel(R) Ethernet Controller" },␊ |
297 | };␊ |
298 | ␊ |
299 | char *get_ethernet_model(uint32_t vendor_id, uint32_t device_id)␊ |
300 | {␊ |
301 | ␉int i = 0;␊ |
302 | ␉for( ; i < sizeof(known_ethernet_cards) / sizeof(known_ethernet_cards[0]); i++)␊ |
303 | ␉{␊ |
304 | ␉␉if(vendor_id == known_ethernet_cards[i].vendor_id && device_id == known_ethernet_cards[i].device_id)␊ |
305 | ␉␉{␊ |
306 | ␉␉␉return known_ethernet_cards[i].model;␊ |
307 | ␉␉}␊ |
308 | ␉}␊ |
309 | ␉i = 0;␊ |
310 | ␉for ( ; i < sizeof(generic_ethernet_cards) / sizeof(generic_ethernet_cards[0]); i++)␊ |
311 | ␉{␊ |
312 | ␉␉if (vendor_id == generic_ethernet_cards[i].vendor_id)␊ |
313 | ␉␉{␊ |
314 | ␉␉␉return generic_ethernet_cards[i].model;␊ |
315 | ␉␉}␊ |
316 | ␉}␊ |
317 | ␉return generic_ethernet_cards[0].model;␊ |
318 | }␊ |
319 | ␊ |
320 | void setup_eth_builtin(pci_dt_t *eth_dev)␊ |
321 | {␊ |
322 | ␉char *devicepath␉= get_pci_dev_path(eth_dev);␊ |
323 | ␉char *name_model␉= NULL;␊ |
324 | ␊ |
325 | ␉DevPropDevice *device = (DevPropDevice *)malloc(sizeof(DevPropDevice));␊ |
326 | ␊ |
327 | ␉verbose("LAN Controller [%04x:%04x] :: %s\n", eth_dev->vendor_id, eth_dev->device_id, devicepath);␊ |
328 | ␊ |
329 | ␉if (!string)␊ |
330 | ␉{␊ |
331 | ␉␉string = devprop_create_string();␊ |
332 | ␉␉if (!string)␊ |
333 | ␉␉{␊ |
334 | ␉␉␉return;␊ |
335 | ␉␉}␊ |
336 | ␉}␊ |
337 | ␊ |
338 | ␉device = devprop_add_device(string, devicepath);␊ |
339 | ␉if(device)␊ |
340 | ␉{␊ |
341 | ␉␉verbose("Setting up lan keys\n");␊ |
342 | ␉␉name_model = get_ethernet_model(eth_dev->vendor_id, eth_dev->device_id);␊ |
343 | ␊ |
344 | ␉␉devprop_add_network_template(device, eth_dev->vendor_id);␊ |
345 | ␉␉devprop_add_value(device, "model", (uint8_t *)name_model, (strlen(name_model) + 1));␊ |
346 | ␉␉devprop_add_value(device, "device_type", (uint8_t *)"ethernet", sizeof("ethernet"));␊ |
347 | ␊ |
348 | ␉␉stringdata = (uint8_t*)malloc(sizeof(uint8_t) * string->length);␊ |
349 | ␉␉if(stringdata)␊ |
350 | ␉␉{␊ |
351 | ␉␉␉memcpy(stringdata, (uint8_t *)devprop_generate_string(string), string->length);␊ |
352 | ␉␉␉stringlength = string->length;␊ |
353 | ␉␉}␊ |
354 | ␉}␊ |
355 | }␊ |
356 | ␊ |
357 | static network_device known_wifi_cards[] =␊ |
358 | {␊ |
359 | ␉// Broadcom␊ |
360 | ␉{PCI_VENDOR_ID_BROADCOM, 0x4312, "Broadcom BCM4311 802.11a/b/g"},␊ |
361 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4313, "Broadcom BCM4311 802.11a" },␊ |
362 | ␉{PCI_VENDOR_ID_BROADCOM, 0x4315, "Broadcom BCM4312 802.11b/g Wireless LAN Controller"},␊ |
363 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4318, "Broadcom BCM4318 [AirForce One 54g] 802.11g Wireless LAN Controller"},␊ |
364 | ␉{PCI_VENDOR_ID_BROADCOM, 0x4319, "Broadcom BCM4318 [AirForce 54g] 802.11a/b/g PCI Express Transceiver"},␊ |
365 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4320, "Broadcom BCM4306 802.11b/g Wireless LAN Controller"},␊ |
366 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4321, "Broadcom BCM4321 802.11a Wireless Network Controller"},␊ |
367 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4322, "Broadcom BCM4322 802.11bgn Wireless Network Controller"},␊ |
368 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4324, "Broadcom BCM4309 802.11abg Wireless Network Controller"},␊ |
369 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4325, "Broadcom BCM4306 802.11bg Wireless Network Controller"},␊ |
370 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4328, "Broadcom BCM4321 802.11a/b/g/n"},␊ |
371 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4329, "Broadcom BCM4321 802.11b/g/n"},␊ |
372 | //␉{PCI_VENDOR_ID_BROADCOM, 0x432a, "Broadcom BCM4321 802.11an Wireless Network Controller"},␊ |
373 | ␉{PCI_VENDOR_ID_BROADCOM, 0x432b, "Broadcom BCM4322 802.11a/b/g/n Wireless LAN Controller"},␊ |
374 | ␉{PCI_VENDOR_ID_BROADCOM, 0x432c, "Broadcom BCM4322 802.11b/g/n"},␊ |
375 | //␉{PCI_VENDOR_ID_BROADCOM, 0x432d, "Broadcom BCM4322 802.11an Wireless Network Controller"},␊ |
376 | ␉{PCI_VENDOR_ID_BROADCOM, 0x4331, "Broadcom BCM4331 802.11a/b/g/n"},␊ |
377 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4350, "Broadcom BCM43222 Wireless Network Adapter"},␊ |
378 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4351, "Broadcom BCM43222 802.11abgn Wireless Network Adapter"},␊ |
379 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4353, "Broadcom BCM43224 802.11a/b/g/n"},␊ |
380 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4357, "Broadcom BCM43225 802.11b/g/n"},␊ |
381 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4358, "Broadcom BCM43227 802.11b/g/n"},␊ |
382 | ␉{PCI_VENDOR_ID_BROADCOM, 0x4359, "Broadcom BCM43228 802.11a/b/g/n"},␊ |
383 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4360, "Broadcom BCM4360 802.11ac Wireless Network Adapter"},␊ |
384 | //␉{PCI_VENDOR_ID_BROADCOM, 0x4365, "Broadcom BCM43142 802.11b/g/n"},␊ |
385 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43a0, "Broadcom BCM4360 802.11ac Wireless Network Adapter"},␊ |
386 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43a1, "Broadcom BCM4360 802.11ac Wireless Network Adapter"},␊ |
387 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43a2, "Broadcom BCM4360 802.11ac Wireless Network Adapter"},␊ |
388 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43a9, "Broadcom BCM43217 802.11b/g/n"},␊ |
389 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43aa, "Broadcom BCM43131 802.11b/g/n"},␊ |
390 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43b1, "Broadcom BCM4352 802.11ac Wireless Network Adapter"},␊ |
391 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43ba, "Broadcom BCM43602 802.11ac Wireless LAN SoC"},␊ |
392 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43bb, "Broadcom BCM43602 802.11ac Wireless LAN SoC"},␊ |
393 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43bc, "Broadcom BCM43602 802.11ac Wireless LAN SoC"},␊ |
394 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43d3, "Broadcom BCM43567 802.11ac Wireless Network Adapter"},␊ |
395 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43d9, "Broadcom BCM43570 802.11ac Wireless Network Adapter"},␊ |
396 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43df, "Broadcom BCM4354 802.11ac Wireless LAN SoC"},␊ |
397 | //␉{PCI_VENDOR_ID_BROADCOM, 0x43ec, "Broadcom BCM4356 802.11ac Wireless Network Adapter"},␊ |
398 | //␉{PCI_VENDOR_ID_BROADCOM, 0xa8d8, "Broadcom BCM43224/5 Wireless Network Adapter"},␊ |
399 | ␊ |
400 | ␉// Atheros␊ |
401 | ␉{PCI_VENDOR_ID_ATHEROS, 0x0020, "Atheros AR5513 802.11abg Wireless NIC"},␊ |
402 | ␉{PCI_VENDOR_ID_ATHEROS, 0x0023, "Atheros AR5416 Wireless Network Adapter [AR5008 802.11(a)bgn]"},␊ |
403 | ␉{PCI_VENDOR_ID_ATHEROS, 0x0024, "Atheros AR5418 Wireless Network Adapter [AR5008E 802.11(a)bgn]"},␊ |
404 | ␉{PCI_VENDOR_ID_ATHEROS, 0x0027, "Atheros AR9160 Wireless Network Adapter [AR9001 802.11(a)bgn]"},␊ |
405 | ␉{PCI_VENDOR_ID_ATHEROS, 0x0029, "Atheros AR922X Wireless Network Adapter"},␊ |
406 | ␉{PCI_VENDOR_ID_ATHEROS, 0x002A, "Atheros AR928X Wireless Network Adapter"}, // "pci168c,2a"␊ |
407 | ␉{PCI_VENDOR_ID_ATHEROS, 0x002B, "Atheros AR9285 Wireless Network Adapter"},␊ |
408 | //␉{PCI_VENDOR_ID_ATHEROS, 0x002c, "Atheros AR2427 802.11bg Wireless Network Adapter (PCI-Express)"},␊ |
409 | //␉{PCI_VENDOR_ID_ATHEROS, 0x002d, "Atheros AR9227 Wireless Network Adapter"},␊ |
410 | //␉{PCI_VENDOR_ID_ATHEROS, 0x002e, "Atheros AR9287 Wireless Network Adapter (PCI-Express)"},␊ |
411 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0030, "Atheros AR93xx Wireless Network Adapter"},␊ |
412 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0032, "Atheros AR9485 Wireless Network Adapter"},␊ |
413 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0033, "Atheros AR9580 Wireless Network Adapter"},␊ |
414 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0034, "Atheros AR9462 Wireless Network Adapter"},␊ |
415 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0036, "Atheros QCA9565 / AR9565 Wireless Network Adapter"},␊ |
416 | //␉{PCI_VENDOR_ID_ATHEROS, 0x0037, "Atheros AR9485 Wireless Network Adapter"},␊ |
417 | };␊ |
418 | ␊ |
419 | void setup_wifi_airport(pci_dt_t *wlan_dev) // ARPT␊ |
420 | {␊ |
421 | ␉char tmp[16];␊ |
422 | ␉builtin = 0;␊ |
423 | ␉DevPropDevice *device ;␊ |
424 | ␉char *devicepath = get_pci_dev_path(wlan_dev);␊ |
425 | ␊ |
426 | ␉verbose("Wifi Controller [%04x:%04x]\n", wlan_dev->vendor_id, wlan_dev->device_id);␊ |
427 | ␊ |
428 | ␉if (!string)␊ |
429 | ␉{␊ |
430 | ␉␉string = devprop_create_string();␊ |
431 | ␉␉if (!string)␊ |
432 | ␉␉{␊ |
433 | ␉␉␉return;␊ |
434 | ␉␉}␊ |
435 | ␉}␊ |
436 | ␊ |
437 | ␉device = devprop_add_device(string, devicepath);␊ |
438 | ␉if(device)␊ |
439 | ␉{␊ |
440 | ␉␉snprintf(tmp, sizeof(tmp),"Airport");␊ |
441 | ␉␉devprop_add_value(device, "AAPL,slot-name", (uint8_t *) tmp, strlen(tmp) + 1);␊ |
442 | ␉␉devprop_add_value(device, "device_type", (uint8_t *) tmp, strlen(tmp) + 1);␊ |
443 | ␉␉devprop_add_value(device, "built-in", (uint8_t *)&builtin, 1);␊ |
444 | ␊ |
445 | ␉␉unsigned int i = 0;␊ |
446 | ␉␉for( ; i < sizeof(known_wifi_cards) / sizeof(known_wifi_cards[0]); i++)␊ |
447 | ␉␉{␊ |
448 | ␉␉␉if(wlan_dev->vendor_id == known_wifi_cards[i].vendor_id && wlan_dev->device_id == known_wifi_cards[i].device_id)␊ |
449 | ␉␉␉{␊ |
450 | ␉␉␉␉verbose("Setting up wifi keys\n");␊ |
451 | ␊ |
452 | ␉␉␉␉devprop_add_value(device, "model", (uint8_t *)known_wifi_cards[i].model, (strlen(known_wifi_cards[i].model) + 1));␊ |
453 | ␉␉␉␉// NOTE: I would set the subsystem id and subsystem vendor id here,␊ |
454 | ␉␉␉␉// however, those values seem to be ovverriden in the boot process.␊ |
455 | ␉␉␉␉// A better method would be injecting the DTGP dsdt method␊ |
456 | ␉␉␉␉// and then injecting the subsystem id there.␊ |
457 | ␊ |
458 | ␉␉␉␉stringdata = (uint8_t *)malloc(sizeof(uint8_t) *string->length);␊ |
459 | ␉␉␉␉if(stringdata)␊ |
460 | ␉␉␉␉{␊ |
461 | ␉␉␉␉␉memcpy(stringdata, (uint8_t *)devprop_generate_string(string), string->length);␊ |
462 | ␉␉␉␉␉stringlength = string->length;␊ |
463 | ␉␉␉␉}␊ |
464 | ␉␉␉␉return;␊ |
465 | ␉␉␉}␊ |
466 | ␉␉}␊ |
467 | ␉}␊ |
468 | }␊ |
469 | |