vsc9953.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. /*
  2. * vsc9953.h
  3. *
  4. * Driver for the Vitesse VSC9953 L2 Switch
  5. *
  6. * This software may be used and distributed according to the
  7. * terms of the GNU Public License, Version 2, incorporated
  8. * herein by reference.
  9. *
  10. * Copyright 2013 Freescale Semiconductor, Inc.
  11. *
  12. */
  13. #ifndef _VSC9953_H_
  14. #define _VSC9953_H_
  15. #include <config.h>
  16. #include <miiphy.h>
  17. #include <asm/types.h>
  18. #define VSC9953_OFFSET (CONFIG_SYS_CCSRBAR_DEFAULT + 0x800000)
  19. #define VSC9953_SYS_OFFSET 0x010000
  20. #define VSC9953_REW_OFFSET 0x030000
  21. #define VSC9953_DEV_GMII_OFFSET 0x100000
  22. #define VSC9953_QSYS_OFFSET 0x200000
  23. #define VSC9953_ANA_OFFSET 0x280000
  24. #define VSC9953_DEVCPU_GCB 0x070000
  25. #define VSC9953_ES0 0x040000
  26. #define VSC9953_IS1 0x050000
  27. #define VSC9953_IS2 0x060000
  28. #define T1040_SWITCH_GMII_DEV_OFFSET 0x010000
  29. #define VSC9953_PHY_REGS_OFFST 0x0000AC
  30. /* Macros for vsc9953_chip_regs.soft_rst register */
  31. #define VSC9953_SOFT_SWC_RST_ENA 0x00000001
  32. /* Macros for vsc9953_sys_sys.reset_cfg register */
  33. #define VSC9953_CORE_ENABLE 0x80
  34. #define VSC9953_MEM_ENABLE 0x40
  35. #define VSC9953_MEM_INIT 0x20
  36. /* Macros for vsc9953_dev_gmii_mac_cfg_status.mac_ena_cfg register */
  37. #define VSC9953_MAC_ENA_CFG 0x00000011
  38. /* Macros for vsc9953_dev_gmii_mac_cfg_status.mac_mode_cfg register */
  39. #define VSC9953_MAC_MODE_CFG 0x00000011
  40. /* Macros for vsc9953_dev_gmii_mac_cfg_status.mac_ifg_cfg register */
  41. #define VSC9953_MAC_IFG_CFG 0x00000515
  42. /* Macros for vsc9953_dev_gmii_mac_cfg_status.mac_hdx_cfg register */
  43. #define VSC9953_MAC_HDX_CFG 0x00001043
  44. /* Macros for vsc9953_dev_gmii_mac_cfg_status.mac_maxlen_cfg register */
  45. #define VSC9953_MAC_MAX_LEN 0x000005ee
  46. /* Macros for vsc9953_dev_gmii_port_mode.clock_cfg register */
  47. #define VSC9953_CLOCK_CFG 0x00000001
  48. #define VSC9953_CLOCK_CFG_1000M 0x00000001
  49. /* Macros for vsc9953_sys_sys.front_port_mode register */
  50. #define VSC9953_FRONT_PORT_MODE 0x00000000
  51. /* Macros for vsc9953_ana_pfc.pfc_cfg register */
  52. #define VSC9953_PFC_FC 0x00000001
  53. #define VSC9953_PFC_FC_QSGMII 0x00000000
  54. /* Macros for vsc9953_sys_pause_cfg.mac_fc_cfg register */
  55. #define VSC9953_MAC_FC_CFG 0x04700000
  56. #define VSC9953_MAC_FC_CFG_QSGMII 0x00700000
  57. /* Macros for vsc9953_sys_pause_cfg.pause_cfg register */
  58. #define VSC9953_PAUSE_CFG 0x001ffffe
  59. /* Macros for vsc9953_sys_pause_cfgtot_tail_drop_lvl register */
  60. #define VSC9953_TOT_TAIL_DROP_LVL 0x000003ff
  61. /* Macros for vsc9953_sys_sys.stat_cfg register */
  62. #define VSC9953_STAT_CLEAR_RX 0x00000400
  63. #define VSC9953_STAT_CLEAR_TX 0x00000800
  64. #define VSC9953_STAT_CLEAR_DR 0x00001000
  65. /* Macros for vsc9953_vcap_core_cfg.vcap_mv_cfg register */
  66. #define VSC9953_VCAP_MV_CFG 0x0000ffff
  67. #define VSC9953_VCAP_UPDATE_CTRL 0x01000004
  68. /* Macros for register vsc9953_ana_ana_tables.mac_access register */
  69. #define VSC9953_MAC_CMD_IDLE 0x00000000
  70. #define VSC9953_MAC_CMD_LEARN 0x00000001
  71. #define VSC9953_MAC_CMD_FORGET 0x00000002
  72. #define VSC9953_MAC_CMD_AGE 0x00000003
  73. #define VSC9953_MAC_CMD_NEXT 0x00000004
  74. #define VSC9953_MAC_CMD_READ 0x00000006
  75. #define VSC9953_MAC_CMD_WRITE 0x00000007
  76. #define VSC9953_MAC_CMD_MASK 0x00000007
  77. #define VSC9953_MAC_CMD_VALID 0x00000800
  78. #define VSC9953_MAC_ENTRYTYPE_NORMAL 0x00000000
  79. #define VSC9953_MAC_ENTRYTYPE_LOCKED 0x00000200
  80. #define VSC9953_MAC_ENTRYTYPE_IPV4MCAST 0x00000400
  81. #define VSC9953_MAC_ENTRYTYPE_IPV6MCAST 0x00000600
  82. #define VSC9953_MAC_ENTRYTYPE_MASK 0x00000600
  83. #define VSC9953_MAC_DESTIDX_MASK 0x000001f8
  84. #define VSC9953_MAC_VID_MASK 0x1fff0000
  85. #define VSC9953_MAC_MACH_MASK 0x0000ffff
  86. /* Macros for vsc9953_ana_port.vlan_cfg register */
  87. #define VSC9953_VLAN_CFG_AWARE_ENA 0x00100000
  88. #define VSC9953_VLAN_CFG_POP_CNT_MASK 0x000c0000
  89. #define VSC9953_VLAN_CFG_VID_MASK 0x00000fff
  90. /* Macros for vsc9953_rew_port.port_vlan_cfg register */
  91. #define VSC9953_PORT_VLAN_CFG_VID_MASK 0x00000fff
  92. /* Macros for vsc9953_ana_ana_tables.vlan_tidx register */
  93. #define VSC9953_ANA_TBL_VID_MASK 0x00000fff
  94. /* Macros for vsc9953_ana_ana_tables.vlan_access register */
  95. #define VSC9953_VLAN_PORT_MASK 0x00001ffc
  96. #define VSC9953_VLAN_CMD_MASK 0x00000003
  97. #define VSC9953_VLAN_CMD_IDLE 0x00000000
  98. #define VSC9953_VLAN_CMD_READ 0x00000001
  99. #define VSC9953_VLAN_CMD_WRITE 0x00000002
  100. #define VSC9953_VLAN_CMD_INIT 0x00000003
  101. /* Macros for vsc9953_ana_port.port_cfg register */
  102. #define VSC9953_PORT_CFG_LEARN_ENA 0x00000080
  103. #define VSC9953_PORT_CFG_LEARN_AUTO 0x00000100
  104. #define VSC9953_PORT_CFG_LEARN_CPU 0x00000200
  105. #define VSC9953_PORT_CFG_LEARN_DROP 0x00000400
  106. /* Macros for vsc9953_qsys_sys.switch_port_mode register */
  107. #define VSC9953_PORT_ENA 0x00002000
  108. /* Macros for vsc9953_ana_ana.adv_learn register */
  109. #define VSC9953_VLAN_CHK 0x00000400
  110. /* Macros for vsc9953_rew_port.port_tag_cfg register */
  111. #define VSC9953_TAG_CFG_MASK 0x00000180
  112. #define VSC9953_TAG_CFG_NONE 0x00000000
  113. #define VSC9953_TAG_CFG_ALL_BUT_PVID_ZERO 0x00000080
  114. #define VSC9953_TAG_CFG_ALL_BUT_ZERO 0x00000100
  115. #define VSC9953_TAG_CFG_ALL 0x00000180
  116. /* Macros for vsc9953_ana_ana.anag_efil register */
  117. #define VSC9953_AGE_PORT_EN 0x00080000
  118. #define VSC9953_AGE_PORT_MASK 0x0007c000
  119. #define VSC9953_AGE_VID_EN 0x00002000
  120. #define VSC9953_AGE_VID_MASK 0x00001fff
  121. /* Macros for vsc9953_ana_ana_tables.mach_data register */
  122. #define VSC9953_MACHDATA_VID_MASK 0x1fff0000
  123. #define VSC9953_MAX_PORTS 10
  124. #define VSC9953_PORT_CHECK(port) \
  125. (((port) < 0 || (port) >= VSC9953_MAX_PORTS) ? 0 : 1)
  126. #define VSC9953_INTERNAL_PORT_CHECK(port) ( \
  127. ( \
  128. (port) < VSC9953_MAX_PORTS - 2 || (port) >= VSC9953_MAX_PORTS \
  129. ) ? 0 : 1 \
  130. )
  131. #define VSC9953_MAX_VLAN 4096
  132. #define VSC9953_VLAN_CHECK(vid) \
  133. (((vid) < 0 || (vid) >= VSC9953_MAX_VLAN) ? 0 : 1)
  134. #define DEFAULT_VSC9953_MDIO_NAME "VSC9953_MDIO0"
  135. #define MIIMIND_OPR_PEND 0x00000004
  136. struct vsc9953_mdio_info {
  137. struct vsc9953_mii_mng *regs;
  138. char *name;
  139. };
  140. /* VSC9953 ANA structure */
  141. struct vsc9953_ana_port {
  142. u32 vlan_cfg;
  143. u32 drop_cfg;
  144. u32 qos_cfg;
  145. u32 vcap_cfg;
  146. u32 vcap_s1_key_cfg[3];
  147. u32 vcap_s2_cfg;
  148. u32 qos_pcp_dei_map_cfg[16];
  149. u32 cpu_fwd_cfg;
  150. u32 cpu_fwd_bpdu_cfg;
  151. u32 cpu_fwd_garp_cfg;
  152. u32 cpu_fwd_ccm_cfg;
  153. u32 port_cfg;
  154. u32 pol_cfg;
  155. u32 reserved[34];
  156. };
  157. struct vsc9953_ana_pol {
  158. u32 pol_pir_cfg;
  159. u32 pol_cir_cfg;
  160. u32 pol_mode_cfg;
  161. u32 pol_pir_state;
  162. u32 pol_cir_state;
  163. u32 reserved1[3];
  164. };
  165. struct vsc9953_ana_ana_tables {
  166. u32 entry_lim[11];
  167. u32 an_moved;
  168. u32 mach_data;
  169. u32 macl_data;
  170. u32 mac_access;
  171. u32 mact_indx;
  172. u32 vlan_access;
  173. u32 vlan_tidx;
  174. };
  175. struct vsc9953_ana_ana {
  176. u32 adv_learn;
  177. u32 vlan_mask;
  178. u32 reserved;
  179. u32 anag_efil;
  180. u32 an_events;
  181. u32 storm_limit_burst;
  182. u32 storm_limit_cfg[4];
  183. u32 isolated_prts;
  184. u32 community_ports;
  185. u32 auto_age;
  186. u32 mac_options;
  187. u32 learn_disc;
  188. u32 agen_ctrl;
  189. u32 mirror_ports;
  190. u32 emirror_ports;
  191. u32 flooding;
  192. u32 flooding_ipmc;
  193. u32 sflow_cfg[11];
  194. u32 port_mode[12];
  195. };
  196. struct vsc9953_ana_pgid {
  197. u32 port_grp_id[91];
  198. };
  199. struct vsc9953_ana_pfc {
  200. u32 pfc_cfg;
  201. u32 reserved1[15];
  202. };
  203. struct vsc9953_ana_pol_misc {
  204. u32 pol_flowc[10];
  205. u32 reserved1[17];
  206. u32 pol_hyst;
  207. };
  208. struct vsc9953_ana_common {
  209. u32 aggr_cfg;
  210. u32 cpuq_cfg;
  211. u32 cpuq_8021_cfg;
  212. u32 dscp_cfg;
  213. u32 dscp_rewr_cfg;
  214. u32 vcap_rng_type_cfg;
  215. u32 vcap_rng_val_cfg;
  216. u32 discard_cfg;
  217. u32 fid_cfg;
  218. };
  219. struct vsc9953_analyzer {
  220. struct vsc9953_ana_port port[11];
  221. u32 reserved1[9536];
  222. struct vsc9953_ana_pol pol[164];
  223. struct vsc9953_ana_ana_tables ana_tables;
  224. u32 reserved2[14];
  225. struct vsc9953_ana_ana ana;
  226. u32 reserved3[22];
  227. struct vsc9953_ana_pgid port_id_tbl;
  228. u32 reserved4[549];
  229. struct vsc9953_ana_pfc pfc[10];
  230. struct vsc9953_ana_pol_misc pol_misc;
  231. u32 reserved5[196];
  232. struct vsc9953_ana_common common;
  233. };
  234. /* END VSC9953 ANA structure t*/
  235. /* VSC9953 DEV_GMII structure */
  236. struct vsc9953_dev_gmii_port_mode {
  237. u32 clock_cfg;
  238. u32 port_misc;
  239. u32 reserved1;
  240. u32 eee_cfg;
  241. };
  242. struct vsc9953_dev_gmii_mac_cfg_status {
  243. u32 mac_ena_cfg;
  244. u32 mac_mode_cfg;
  245. u32 mac_maxlen_cfg;
  246. u32 mac_tags_cfg;
  247. u32 mac_adv_chk_cfg;
  248. u32 mac_ifg_cfg;
  249. u32 mac_hdx_cfg;
  250. u32 mac_fc_mac_low_cfg;
  251. u32 mac_fc_mac_high_cfg;
  252. u32 mac_sticky;
  253. };
  254. struct vsc9953_dev_gmii {
  255. struct vsc9953_dev_gmii_port_mode port_mode;
  256. struct vsc9953_dev_gmii_mac_cfg_status mac_cfg_status;
  257. };
  258. /* END VSC9953 DEV_GMII structure */
  259. /* VSC9953 QSYS structure */
  260. struct vsc9953_qsys_hsch {
  261. u32 cir_cfg;
  262. u32 reserved1;
  263. u32 se_cfg;
  264. u32 se_dwrr_cfg[8];
  265. u32 cir_state;
  266. u32 reserved2[20];
  267. };
  268. struct vsc9953_qsys_sys {
  269. u32 port_mode[12];
  270. u32 switch_port_mode[11];
  271. u32 stat_cnt_cfg;
  272. u32 eee_cfg[10];
  273. u32 eee_thrs;
  274. u32 igr_no_sharing;
  275. u32 egr_no_sharing;
  276. u32 sw_status[11];
  277. u32 ext_cpu_cfg;
  278. u32 cpu_group_map;
  279. u32 reserved1[23];
  280. };
  281. struct vsc9953_qsys_qos_cfg {
  282. u32 red_profile[16];
  283. u32 res_qos_mode;
  284. };
  285. struct vsc9953_qsys_drop_cfg {
  286. u32 egr_drop_mode;
  287. };
  288. struct vsc9953_qsys_mmgt {
  289. u32 eq_cntrl;
  290. u32 reserved1;
  291. };
  292. struct vsc9953_qsys_hsch_misc {
  293. u32 hsch_misc_cfg;
  294. u32 reserved1[546];
  295. };
  296. struct vsc9953_qsys_res_ctrl {
  297. u32 res_cfg;
  298. u32 res_stat;
  299. };
  300. struct vsc9953_qsys_reg {
  301. struct vsc9953_qsys_hsch hsch[108];
  302. struct vsc9953_qsys_sys sys;
  303. struct vsc9953_qsys_qos_cfg qos_cfg;
  304. struct vsc9953_qsys_drop_cfg drop_cfg;
  305. struct vsc9953_qsys_mmgt mmgt;
  306. struct vsc9953_qsys_hsch_misc hsch_misc;
  307. struct vsc9953_qsys_res_ctrl res_ctrl[1024];
  308. };
  309. /* END VSC9953 QSYS structure */
  310. /* VSC9953 SYS structure */
  311. struct vsc9953_rx_cntrs {
  312. u32 c_rx_oct;
  313. u32 c_rx_uc;
  314. u32 c_rx_mc;
  315. u32 c_rx_bc;
  316. u32 c_rx_short;
  317. u32 c_rx_frag;
  318. u32 c_rx_jabber;
  319. u32 c_rx_crc;
  320. u32 c_rx_symbol_err;
  321. u32 c_rx_sz_64;
  322. u32 c_rx_sz_65_127;
  323. u32 c_rx_sz_128_255;
  324. u32 c_rx_sz_256_511;
  325. u32 c_rx_sz_512_1023;
  326. u32 c_rx_sz_1024_1526;
  327. u32 c_rx_sz_jumbo;
  328. u32 c_rx_pause;
  329. u32 c_rx_control;
  330. u32 c_rx_long;
  331. u32 c_rx_cat_drop;
  332. u32 c_rx_red_prio_0;
  333. u32 c_rx_red_prio_1;
  334. u32 c_rx_red_prio_2;
  335. u32 c_rx_red_prio_3;
  336. u32 c_rx_red_prio_4;
  337. u32 c_rx_red_prio_5;
  338. u32 c_rx_red_prio_6;
  339. u32 c_rx_red_prio_7;
  340. u32 c_rx_yellow_prio_0;
  341. u32 c_rx_yellow_prio_1;
  342. u32 c_rx_yellow_prio_2;
  343. u32 c_rx_yellow_prio_3;
  344. u32 c_rx_yellow_prio_4;
  345. u32 c_rx_yellow_prio_5;
  346. u32 c_rx_yellow_prio_6;
  347. u32 c_rx_yellow_prio_7;
  348. u32 c_rx_green_prio_0;
  349. u32 c_rx_green_prio_1;
  350. u32 c_rx_green_prio_2;
  351. u32 c_rx_green_prio_3;
  352. u32 c_rx_green_prio_4;
  353. u32 c_rx_green_prio_5;
  354. u32 c_rx_green_prio_6;
  355. u32 c_rx_green_prio_7;
  356. u32 reserved[20];
  357. };
  358. struct vsc9953_tx_cntrs {
  359. u32 c_tx_oct;
  360. u32 c_tx_uc;
  361. u32 c_tx_mc;
  362. u32 c_tx_bc;
  363. u32 c_tx_col;
  364. u32 c_tx_drop;
  365. u32 c_tx_pause;
  366. u32 c_tx_sz_64;
  367. u32 c_tx_sz_65_127;
  368. u32 c_tx_sz_128_255;
  369. u32 c_tx_sz_256_511;
  370. u32 c_tx_sz_512_1023;
  371. u32 c_tx_sz_1024_1526;
  372. u32 c_tx_sz_jumbo;
  373. u32 c_tx_yellow_prio_0;
  374. u32 c_tx_yellow_prio_1;
  375. u32 c_tx_yellow_prio_2;
  376. u32 c_tx_yellow_prio_3;
  377. u32 c_tx_yellow_prio_4;
  378. u32 c_tx_yellow_prio_5;
  379. u32 c_tx_yellow_prio_6;
  380. u32 c_tx_yellow_prio_7;
  381. u32 c_tx_green_prio_0;
  382. u32 c_tx_green_prio_1;
  383. u32 c_tx_green_prio_2;
  384. u32 c_tx_green_prio_3;
  385. u32 c_tx_green_prio_4;
  386. u32 c_tx_green_prio_5;
  387. u32 c_tx_green_prio_6;
  388. u32 c_tx_green_prio_7;
  389. u32 c_tx_aged;
  390. u32 reserved[33];
  391. };
  392. struct vsc9953_drop_cntrs {
  393. u32 c_dr_local;
  394. u32 c_dr_tail;
  395. u32 c_dr_yellow_prio_0;
  396. u32 c_dr_yellow_prio_1;
  397. u32 c_dr_yellow_prio_2;
  398. u32 c_dr_yellow_prio_3;
  399. u32 c_dr_yellow_prio_4;
  400. u32 c_dr_yellow_prio_5;
  401. u32 c_dr_yellow_prio_6;
  402. u32 c_dr_yellow_prio_7;
  403. u32 c_dr_green_prio_0;
  404. u32 c_dr_green_prio_1;
  405. u32 c_dr_green_prio_2;
  406. u32 c_dr_green_prio_3;
  407. u32 c_dr_green_prio_4;
  408. u32 c_dr_green_prio_5;
  409. u32 c_dr_green_prio_6;
  410. u32 c_dr_green_prio_7;
  411. u32 reserved[46];
  412. };
  413. struct vsc9953_sys_stat {
  414. struct vsc9953_rx_cntrs rx_cntrs;
  415. struct vsc9953_tx_cntrs tx_cntrs;
  416. struct vsc9953_drop_cntrs drop_cntrs;
  417. u32 reserved1[6];
  418. };
  419. struct vsc9953_sys_sys {
  420. u32 reset_cfg;
  421. u32 reserved1;
  422. u32 vlan_etype_cfg;
  423. u32 port_mode[12];
  424. u32 front_port_mode[10];
  425. u32 frame_aging;
  426. u32 stat_cfg;
  427. u32 reserved2[50];
  428. };
  429. struct vsc9953_sys_pause_cfg {
  430. u32 pause_cfg[11];
  431. u32 pause_tot_cfg;
  432. u32 tail_drop_level[11];
  433. u32 tot_tail_drop_lvl;
  434. u32 mac_fc_cfg[10];
  435. };
  436. struct vsc9953_sys_mmgt {
  437. u16 free_cnt;
  438. };
  439. struct vsc9953_system_reg {
  440. struct vsc9953_sys_stat stat;
  441. struct vsc9953_sys_sys sys;
  442. struct vsc9953_sys_pause_cfg pause_cfg;
  443. struct vsc9953_sys_mmgt mmgt;
  444. };
  445. /* END VSC9953 SYS structure */
  446. /* VSC9953 REW structure */
  447. struct vsc9953_rew_port {
  448. u32 port_vlan_cfg;
  449. u32 port_tag_cfg;
  450. u32 port_port_cfg;
  451. u32 port_dscp_cfg;
  452. u32 port_pcp_dei_qos_map_cfg[16];
  453. u32 reserved[12];
  454. };
  455. struct vsc9953_rew_common {
  456. u32 reserve[4];
  457. u32 dscp_remap_dp1_cfg[64];
  458. u32 dscp_remap_cfg[64];
  459. };
  460. struct vsc9953_rew_reg {
  461. struct vsc9953_rew_port port[12];
  462. struct vsc9953_rew_common common;
  463. };
  464. /* END VSC9953 REW structure */
  465. /* VSC9953 DEVCPU_GCB structure */
  466. struct vsc9953_chip_regs {
  467. u32 chipd_id;
  468. u32 gpr;
  469. u32 soft_rst;
  470. };
  471. struct vsc9953_gpio {
  472. u32 gpio_out_set[10];
  473. u32 gpio_out_clr[10];
  474. u32 gpio_out[10];
  475. u32 gpio_in[10];
  476. };
  477. struct vsc9953_mii_mng {
  478. u32 miimstatus;
  479. u32 reserved1;
  480. u32 miimcmd;
  481. u32 miimdata;
  482. u32 miimcfg;
  483. u32 miimscan_0;
  484. u32 miimscan_1;
  485. u32 miiscan_lst_rslts;
  486. u32 miiscan_lst_rslts_valid;
  487. };
  488. struct vsc9953_mii_read_scan {
  489. u32 mii_scan_results_sticky[2];
  490. };
  491. struct vsc9953_devcpu_gcb {
  492. struct vsc9953_chip_regs chip_regs;
  493. struct vsc9953_gpio gpio;
  494. struct vsc9953_mii_mng mii_mng[2];
  495. struct vsc9953_mii_read_scan mii_read_scan;
  496. };
  497. /* END VSC9953 DEVCPU_GCB structure */
  498. /* VSC9953 IS* structure */
  499. struct vsc9953_vcap_core_cfg {
  500. u32 vcap_update_ctrl;
  501. u32 vcap_mv_cfg;
  502. };
  503. struct vsc9953_vcap {
  504. struct vsc9953_vcap_core_cfg vcap_core_cfg;
  505. };
  506. /* END VSC9953 IS* structure */
  507. #define VSC9953_PORT_INFO_INITIALIZER(idx) \
  508. { \
  509. .enabled = 0, \
  510. .phyaddr = 0, \
  511. .index = idx, \
  512. .phy_regs = NULL, \
  513. .enet_if = PHY_INTERFACE_MODE_NONE, \
  514. .bus = NULL, \
  515. .phydev = NULL, \
  516. }
  517. /* Structure to describe a VSC9953 port */
  518. struct vsc9953_port_info {
  519. u8 enabled;
  520. u8 phyaddr;
  521. int index;
  522. void *phy_regs;
  523. phy_interface_t enet_if;
  524. struct mii_dev *bus;
  525. struct phy_device *phydev;
  526. };
  527. /* Structure to describe a VSC9953 switch */
  528. struct vsc9953_info {
  529. struct vsc9953_port_info port[VSC9953_MAX_PORTS];
  530. };
  531. void vsc9953_init(bd_t *bis);
  532. void vsc9953_port_info_set_mdio(int port_no, struct mii_dev *bus);
  533. void vsc9953_port_info_set_phy_address(int port_no, int address);
  534. void vsc9953_port_enable(int port_no);
  535. void vsc9953_port_disable(int port_no);
  536. void vsc9953_port_info_set_phy_int(int port_no, phy_interface_t phy_int);
  537. #endif /* _VSC9953_H_ */