Lines Matching full:sw
39 struct tb_switch *sw; in alloc_switch() local
43 sw = kunit_kzalloc(test, sizeof(*sw), GFP_KERNEL); in alloc_switch()
44 if (!sw) in alloc_switch()
47 sw->config.upstream_port_number = upstream_port; in alloc_switch()
48 sw->config.depth = tb_route_length(route); in alloc_switch()
49 sw->config.route_hi = upper_32_bits(route); in alloc_switch()
50 sw->config.route_lo = lower_32_bits(route); in alloc_switch()
51 sw->config.enabled = 0; in alloc_switch()
52 sw->config.max_port_number = max_port_number; in alloc_switch()
54 size = (sw->config.max_port_number + 1) * sizeof(*sw->ports); in alloc_switch()
55 sw->ports = kunit_kzalloc(test, size, GFP_KERNEL); in alloc_switch()
56 if (!sw->ports) in alloc_switch()
59 for (i = 0; i <= sw->config.max_port_number; i++) { in alloc_switch()
60 sw->ports[i].sw = sw; in alloc_switch()
61 sw->ports[i].port = i; in alloc_switch()
62 sw->ports[i].config.port_number = i; in alloc_switch()
64 kunit_ida_init(test, &sw->ports[i].in_hopids); in alloc_switch()
65 kunit_ida_init(test, &sw->ports[i].out_hopids); in alloc_switch()
69 return sw; in alloc_switch()
74 struct tb_switch *sw; in alloc_host() local
76 sw = alloc_switch(test, 0, 7, 13); in alloc_host()
77 if (!sw) in alloc_host()
80 sw->config.vendor_id = 0x8086; in alloc_host()
81 sw->config.device_id = 0x9a1b; in alloc_host()
83 sw->ports[0].config.type = TB_TYPE_PORT; in alloc_host()
84 sw->ports[0].config.max_in_hop_id = 7; in alloc_host()
85 sw->ports[0].config.max_out_hop_id = 7; in alloc_host()
87 sw->ports[1].config.type = TB_TYPE_PORT; in alloc_host()
88 sw->ports[1].config.max_in_hop_id = 19; in alloc_host()
89 sw->ports[1].config.max_out_hop_id = 19; in alloc_host()
90 sw->ports[1].total_credits = 60; in alloc_host()
91 sw->ports[1].ctl_credits = 2; in alloc_host()
92 sw->ports[1].dual_link_port = &sw->ports[2]; in alloc_host()
94 sw->ports[2].config.type = TB_TYPE_PORT; in alloc_host()
95 sw->ports[2].config.max_in_hop_id = 19; in alloc_host()
96 sw->ports[2].config.max_out_hop_id = 19; in alloc_host()
97 sw->ports[2].total_credits = 60; in alloc_host()
98 sw->ports[2].ctl_credits = 2; in alloc_host()
99 sw->ports[2].dual_link_port = &sw->ports[1]; in alloc_host()
100 sw->ports[2].link_nr = 1; in alloc_host()
102 sw->ports[3].config.type = TB_TYPE_PORT; in alloc_host()
103 sw->ports[3].config.max_in_hop_id = 19; in alloc_host()
104 sw->ports[3].config.max_out_hop_id = 19; in alloc_host()
105 sw->ports[3].total_credits = 60; in alloc_host()
106 sw->ports[3].ctl_credits = 2; in alloc_host()
107 sw->ports[3].dual_link_port = &sw->ports[4]; in alloc_host()
109 sw->ports[4].config.type = TB_TYPE_PORT; in alloc_host()
110 sw->ports[4].config.max_in_hop_id = 19; in alloc_host()
111 sw->ports[4].config.max_out_hop_id = 19; in alloc_host()
112 sw->ports[4].total_credits = 60; in alloc_host()
113 sw->ports[4].ctl_credits = 2; in alloc_host()
114 sw->ports[4].dual_link_port = &sw->ports[3]; in alloc_host()
115 sw->ports[4].link_nr = 1; in alloc_host()
117 sw->ports[5].config.type = TB_TYPE_DP_HDMI_IN; in alloc_host()
118 sw->ports[5].config.max_in_hop_id = 9; in alloc_host()
119 sw->ports[5].config.max_out_hop_id = 9; in alloc_host()
120 sw->ports[5].cap_adap = -1; in alloc_host()
122 sw->ports[6].config.type = TB_TYPE_DP_HDMI_IN; in alloc_host()
123 sw->ports[6].config.max_in_hop_id = 9; in alloc_host()
124 sw->ports[6].config.max_out_hop_id = 9; in alloc_host()
125 sw->ports[6].cap_adap = -1; in alloc_host()
127 sw->ports[7].config.type = TB_TYPE_NHI; in alloc_host()
128 sw->ports[7].config.max_in_hop_id = 11; in alloc_host()
129 sw->ports[7].config.max_out_hop_id = 11; in alloc_host()
130 sw->ports[7].config.nfc_credits = 0x41800000; in alloc_host()
132 sw->ports[8].config.type = TB_TYPE_PCIE_DOWN; in alloc_host()
133 sw->ports[8].config.max_in_hop_id = 8; in alloc_host()
134 sw->ports[8].config.max_out_hop_id = 8; in alloc_host()
136 sw->ports[9].config.type = TB_TYPE_PCIE_DOWN; in alloc_host()
137 sw->ports[9].config.max_in_hop_id = 8; in alloc_host()
138 sw->ports[9].config.max_out_hop_id = 8; in alloc_host()
140 sw->ports[10].disabled = true; in alloc_host()
141 sw->ports[11].disabled = true; in alloc_host()
143 sw->ports[12].config.type = TB_TYPE_USB3_DOWN; in alloc_host()
144 sw->ports[12].config.max_in_hop_id = 8; in alloc_host()
145 sw->ports[12].config.max_out_hop_id = 8; in alloc_host()
147 sw->ports[13].config.type = TB_TYPE_USB3_DOWN; in alloc_host()
148 sw->ports[13].config.max_in_hop_id = 8; in alloc_host()
149 sw->ports[13].config.max_out_hop_id = 8; in alloc_host()
151 return sw; in alloc_host()
156 struct tb_switch *sw; in alloc_host_usb4() local
158 sw = alloc_host(test); in alloc_host_usb4()
159 if (!sw) in alloc_host_usb4()
162 sw->generation = 4; in alloc_host_usb4()
163 sw->credit_allocation = true; in alloc_host_usb4()
164 sw->max_usb3_credits = 32; in alloc_host_usb4()
165 sw->min_dp_aux_credits = 1; in alloc_host_usb4()
166 sw->min_dp_main_credits = 0; in alloc_host_usb4()
167 sw->max_pcie_credits = 64; in alloc_host_usb4()
168 sw->max_dma_credits = 14; in alloc_host_usb4()
170 return sw; in alloc_host_usb4()
178 struct tb_switch *sw; in alloc_dev_default() local
180 sw = alloc_switch(test, route, 1, 19); in alloc_dev_default()
181 if (!sw) in alloc_dev_default()
184 sw->config.vendor_id = 0x8086; in alloc_dev_default()
185 sw->config.device_id = 0x15ef; in alloc_dev_default()
187 sw->ports[0].config.type = TB_TYPE_PORT; in alloc_dev_default()
188 sw->ports[0].config.max_in_hop_id = 8; in alloc_dev_default()
189 sw->ports[0].config.max_out_hop_id = 8; in alloc_dev_default()
191 sw->ports[1].config.type = TB_TYPE_PORT; in alloc_dev_default()
192 sw->ports[1].config.max_in_hop_id = 19; in alloc_dev_default()
193 sw->ports[1].config.max_out_hop_id = 19; in alloc_dev_default()
194 sw->ports[1].total_credits = 60; in alloc_dev_default()
195 sw->ports[1].ctl_credits = 2; in alloc_dev_default()
196 sw->ports[1].dual_link_port = &sw->ports[2]; in alloc_dev_default()
198 sw->ports[2].config.type = TB_TYPE_PORT; in alloc_dev_default()
199 sw->ports[2].config.max_in_hop_id = 19; in alloc_dev_default()
200 sw->ports[2].config.max_out_hop_id = 19; in alloc_dev_default()
201 sw->ports[2].total_credits = 60; in alloc_dev_default()
202 sw->ports[2].ctl_credits = 2; in alloc_dev_default()
203 sw->ports[2].dual_link_port = &sw->ports[1]; in alloc_dev_default()
204 sw->ports[2].link_nr = 1; in alloc_dev_default()
206 sw->ports[3].config.type = TB_TYPE_PORT; in alloc_dev_default()
207 sw->ports[3].config.max_in_hop_id = 19; in alloc_dev_default()
208 sw->ports[3].config.max_out_hop_id = 19; in alloc_dev_default()
209 sw->ports[3].total_credits = 60; in alloc_dev_default()
210 sw->ports[3].ctl_credits = 2; in alloc_dev_default()
211 sw->ports[3].dual_link_port = &sw->ports[4]; in alloc_dev_default()
213 sw->ports[4].config.type = TB_TYPE_PORT; in alloc_dev_default()
214 sw->ports[4].config.max_in_hop_id = 19; in alloc_dev_default()
215 sw->ports[4].config.max_out_hop_id = 19; in alloc_dev_default()
216 sw->ports[4].total_credits = 60; in alloc_dev_default()
217 sw->ports[4].ctl_credits = 2; in alloc_dev_default()
218 sw->ports[4].dual_link_port = &sw->ports[3]; in alloc_dev_default()
219 sw->ports[4].link_nr = 1; in alloc_dev_default()
221 sw->ports[5].config.type = TB_TYPE_PORT; in alloc_dev_default()
222 sw->ports[5].config.max_in_hop_id = 19; in alloc_dev_default()
223 sw->ports[5].config.max_out_hop_id = 19; in alloc_dev_default()
224 sw->ports[5].total_credits = 60; in alloc_dev_default()
225 sw->ports[5].ctl_credits = 2; in alloc_dev_default()
226 sw->ports[5].dual_link_port = &sw->ports[6]; in alloc_dev_default()
228 sw->ports[6].config.type = TB_TYPE_PORT; in alloc_dev_default()
229 sw->ports[6].config.max_in_hop_id = 19; in alloc_dev_default()
230 sw->ports[6].config.max_out_hop_id = 19; in alloc_dev_default()
231 sw->ports[6].total_credits = 60; in alloc_dev_default()
232 sw->ports[6].ctl_credits = 2; in alloc_dev_default()
233 sw->ports[6].dual_link_port = &sw->ports[5]; in alloc_dev_default()
234 sw->ports[6].link_nr = 1; in alloc_dev_default()
236 sw->ports[7].config.type = TB_TYPE_PORT; in alloc_dev_default()
237 sw->ports[7].config.max_in_hop_id = 19; in alloc_dev_default()
238 sw->ports[7].config.max_out_hop_id = 19; in alloc_dev_default()
239 sw->ports[7].total_credits = 60; in alloc_dev_default()
240 sw->ports[7].ctl_credits = 2; in alloc_dev_default()
241 sw->ports[7].dual_link_port = &sw->ports[8]; in alloc_dev_default()
243 sw->ports[8].config.type = TB_TYPE_PORT; in alloc_dev_default()
244 sw->ports[8].config.max_in_hop_id = 19; in alloc_dev_default()
245 sw->ports[8].config.max_out_hop_id = 19; in alloc_dev_default()
246 sw->ports[8].total_credits = 60; in alloc_dev_default()
247 sw->ports[8].ctl_credits = 2; in alloc_dev_default()
248 sw->ports[8].dual_link_port = &sw->ports[7]; in alloc_dev_default()
249 sw->ports[8].link_nr = 1; in alloc_dev_default()
251 sw->ports[9].config.type = TB_TYPE_PCIE_UP; in alloc_dev_default()
252 sw->ports[9].config.max_in_hop_id = 8; in alloc_dev_default()
253 sw->ports[9].config.max_out_hop_id = 8; in alloc_dev_default()
255 sw->ports[10].config.type = TB_TYPE_PCIE_DOWN; in alloc_dev_default()
256 sw->ports[10].config.max_in_hop_id = 8; in alloc_dev_default()
257 sw->ports[10].config.max_out_hop_id = 8; in alloc_dev_default()
259 sw->ports[11].config.type = TB_TYPE_PCIE_DOWN; in alloc_dev_default()
260 sw->ports[11].config.max_in_hop_id = 8; in alloc_dev_default()
261 sw->ports[11].config.max_out_hop_id = 8; in alloc_dev_default()
263 sw->ports[12].config.type = TB_TYPE_PCIE_DOWN; in alloc_dev_default()
264 sw->ports[12].config.max_in_hop_id = 8; in alloc_dev_default()
265 sw->ports[12].config.max_out_hop_id = 8; in alloc_dev_default()
267 sw->ports[13].config.type = TB_TYPE_DP_HDMI_OUT; in alloc_dev_default()
268 sw->ports[13].config.max_in_hop_id = 9; in alloc_dev_default()
269 sw->ports[13].config.max_out_hop_id = 9; in alloc_dev_default()
270 sw->ports[13].cap_adap = -1; in alloc_dev_default()
272 sw->ports[14].config.type = TB_TYPE_DP_HDMI_OUT; in alloc_dev_default()
273 sw->ports[14].config.max_in_hop_id = 9; in alloc_dev_default()
274 sw->ports[14].config.max_out_hop_id = 9; in alloc_dev_default()
275 sw->ports[14].cap_adap = -1; in alloc_dev_default()
277 sw->ports[15].disabled = true; in alloc_dev_default()
279 sw->ports[16].config.type = TB_TYPE_USB3_UP; in alloc_dev_default()
280 sw->ports[16].config.max_in_hop_id = 8; in alloc_dev_default()
281 sw->ports[16].config.max_out_hop_id = 8; in alloc_dev_default()
283 sw->ports[17].config.type = TB_TYPE_USB3_DOWN; in alloc_dev_default()
284 sw->ports[17].config.max_in_hop_id = 8; in alloc_dev_default()
285 sw->ports[17].config.max_out_hop_id = 8; in alloc_dev_default()
287 sw->ports[18].config.type = TB_TYPE_USB3_DOWN; in alloc_dev_default()
288 sw->ports[18].config.max_in_hop_id = 8; in alloc_dev_default()
289 sw->ports[18].config.max_out_hop_id = 8; in alloc_dev_default()
291 sw->ports[19].config.type = TB_TYPE_USB3_DOWN; in alloc_dev_default()
292 sw->ports[19].config.max_in_hop_id = 8; in alloc_dev_default()
293 sw->ports[19].config.max_out_hop_id = 8; in alloc_dev_default()
296 return sw; in alloc_dev_default()
299 upstream_port = tb_upstream_port(sw); in alloc_dev_default()
320 return sw; in alloc_dev_default()
327 struct tb_switch *sw; in alloc_dev_with_dpin() local
329 sw = alloc_dev_default(test, parent, route, bonded); in alloc_dev_with_dpin()
330 if (!sw) in alloc_dev_with_dpin()
333 sw->ports[13].config.type = TB_TYPE_DP_HDMI_IN; in alloc_dev_with_dpin()
334 sw->ports[13].config.max_in_hop_id = 9; in alloc_dev_with_dpin()
335 sw->ports[13].config.max_out_hop_id = 9; in alloc_dev_with_dpin()
337 sw->ports[14].config.type = TB_TYPE_DP_HDMI_IN; in alloc_dev_with_dpin()
338 sw->ports[14].config.max_in_hop_id = 9; in alloc_dev_with_dpin()
339 sw->ports[14].config.max_out_hop_id = 9; in alloc_dev_with_dpin()
341 return sw; in alloc_dev_with_dpin()
348 struct tb_switch *sw; in alloc_dev_without_dp() local
351 sw = alloc_dev_default(test, parent, route, bonded); in alloc_dev_without_dp()
352 if (!sw) in alloc_dev_without_dp()
363 sw->ports[i].disabled = true; in alloc_dev_without_dp()
366 sw->ports[i].disabled = true; in alloc_dev_without_dp()
368 sw->ports[13].cap_adap = 0; in alloc_dev_without_dp()
369 sw->ports[14].cap_adap = 0; in alloc_dev_without_dp()
372 sw->ports[i].disabled = true; in alloc_dev_without_dp()
374 sw->generation = 4; in alloc_dev_without_dp()
375 sw->credit_allocation = true; in alloc_dev_without_dp()
376 sw->max_usb3_credits = 109; in alloc_dev_without_dp()
377 sw->min_dp_aux_credits = 0; in alloc_dev_without_dp()
378 sw->min_dp_main_credits = 0; in alloc_dev_without_dp()
379 sw->max_pcie_credits = 30; in alloc_dev_without_dp()
380 sw->max_dma_credits = 1; in alloc_dev_without_dp()
382 return sw; in alloc_dev_without_dp()
389 struct tb_switch *sw; in alloc_dev_usb4() local
391 sw = alloc_dev_default(test, parent, route, bonded); in alloc_dev_usb4()
392 if (!sw) in alloc_dev_usb4()
395 sw->generation = 4; in alloc_dev_usb4()
396 sw->credit_allocation = true; in alloc_dev_usb4()
397 sw->max_usb3_credits = 14; in alloc_dev_usb4()
398 sw->min_dp_aux_credits = 1; in alloc_dev_usb4()
399 sw->min_dp_main_credits = 18; in alloc_dev_usb4()
400 sw->max_pcie_credits = 32; in alloc_dev_usb4()
401 sw->max_dma_credits = 14; in alloc_dev_usb4()
403 return sw; in alloc_dev_usb4()
494 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_single_hop_walk()
506 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_single_hop_walk()
553 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_daisy_chain_walk()
565 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_daisy_chain_walk()
616 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_simple_tree_walk()
628 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_simple_tree_walk()
700 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_complex_tree_walk()
712 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_complex_tree_walk()
803 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_max_length_walk()
815 KUNIT_EXPECT_EQ(test, tb_route(p->sw), test_data[i].route); in tb_test_path_max_length_walk()
899 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane0()
903 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane0()
961 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1()
965 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1()
1041 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1_chain()
1045 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1_chain()
1121 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1_chain_reverse()
1125 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_not_bonded_lane1_chain_reverse()
1213 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_mixed_chain()
1217 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_mixed_chain()
1305 KUNIT_EXPECT_EQ(test, tb_route(in_port->sw), test_data[i].route); in tb_test_path_mixed_chain_reverse()
1309 KUNIT_EXPECT_EQ(test, tb_route(out_port->sw), test_data[i].route); in tb_test_path_mixed_chain_reverse()