#if !defined(_AVM_NET_CFG_ATHEROS_HW201v2_) #define _AVM_NET_CFG_ATHEROS_HW201v2_ #include #include #include "../switch/atheros/atheros_mac.h" #include "../phy/avmnet_ar803x.h" #include "../phy/avmnet_ar8326.h" #include "../phy/phy_plc.h" #include #if LINUX_VERSION_CODE < KERNEL_VERSION(4,4,46) #include #else #include #endif extern avmnet_module_t HW201v2_gmac1; avmnet_device_t avmnet_hw201v2_avm_device_plc ____cacheline_aligned = { .device = NULL, .device_name = "plc", .external_port_no = 255, .device_ops = { /*--- .ndo_get_stats = athr_gmac_get_stats, ---*/ .ndo_open = avmnet_netdev_open, .ndo_stop = avmnet_netdev_stop, /*--- .ndo_do_ioctl = athr_gmac_do_ioctl, ---*/ .ndo_tx_timeout = athr_gmac_tx_timeout, .ndo_start_xmit = athr_gmac_hard_start }, .mac_module = &HW201v2_gmac1, .vlanID = 5, // GMAC1, SW MAC 5 .sizeof_priv = sizeof(avmnet_netdev_priv_t), .device_setup = athr_gmac_setup_eth, .device_setup_priv = athr_gmac_setup_eth_priv, }; avmnet_device_t avmnet_hw201v2_avm_device_eth1 ____cacheline_aligned = { .device = NULL, .device_name = "eth1", .external_port_no = 1, .device_ops = { /*--- .ndo_get_stats = athr_gmac_get_stats, ---*/ .ndo_open = avmnet_netdev_open, .ndo_stop = avmnet_netdev_stop, /*--- .ndo_do_ioctl = athr_gmac_do_ioctl, ---*/ .ndo_tx_timeout = athr_gmac_tx_timeout, .ndo_start_xmit = athr_gmac_hard_start }, .mac_module = &HW201v2_gmac1, .vlanID = 3, // GMAC1, SW MAC 3 .sizeof_priv = sizeof(avmnet_netdev_priv_t), .device_setup = athr_gmac_setup_eth, .device_setup_priv = athr_gmac_setup_eth_priv, }; avmnet_device_t avmnet_hw201v2_avm_device_eth0 ____cacheline_aligned = { .device = NULL, .device_name = "eth0", .external_port_no = 0, .device_ops = { /*--- .ndo_get_stats = athr_gmac_get_stats, ---*/ .ndo_open = avmnet_netdev_open, .ndo_stop = avmnet_netdev_stop, /*--- .ndo_do_ioctl = athr_gmac_do_ioctl, ---*/ .ndo_tx_timeout = athr_gmac_tx_timeout, .ndo_start_xmit = athr_gmac_hard_start }, .mac_module = &HW201v2_gmac1, .vlanID = 2, // GMAC1, SW MAC 2 .sizeof_priv = sizeof(avmnet_netdev_priv_t), .device_setup = athr_gmac_setup_eth, .device_setup_priv = athr_gmac_setup_eth_priv, }; avmnet_device_t *avmnet_hw201v2_avm_devices[] = { &avmnet_hw201v2_avm_device_plc, // SW MAC 5 &avmnet_hw201v2_avm_device_eth0,// SW MAC 1 &avmnet_hw201v2_avm_device_eth1,// SW MAC 2 }; avmnet_module_t avmnet_HW201v2 ____cacheline_aligned = { .name = "athmac", .type = avmnet_modtype_switch, .priv = NULL, .initdata = { .mac = { .flags = 0 }}, .init = athmac_init, .setup = athmac_setup, .exit = athmac_exit, .lock = athmac_lock, .unlock = athmac_unlock, .trylock = athmac_trylock, .status_changed = athmac_status_changed, .poll = athmac_poll, .set_status = athmac_set_status, .parent = NULL, .num_children = 1, .children = { &HW201v2_gmac1 } }; extern avmnet_module_t HW201v2_ath_switch, HW201v2_module_plc, HW201v2_module_plc_phy, HW201v2_module_eth0, HW201v2_module_eth1; avmnet_module_t HW201v2_gmac1 ____cacheline_aligned = { .name = "gmac1", .type = avmnet_modtype_switch, .priv = NULL, .initdata.mac = { .flags = AVMNET_CONFIG_FLAG_BASEADDR | AVMNET_CONFIG_FLAG_IRQ | AVMNET_CONFIG_FLAG_NO_WANPORT | AVMNET_CONFIG_FLAG_SWITCHPORT, .base_addr = ATH_GE1_BASE, .irq = ATH_CPU_IRQ_GE1, .mac_nr = 1 }, .init = athmac_gmac_init, .setup = athmac_gmac_setup, .exit = athmac_gmac_exit, .lock = athmac_gmac_lock, .unlock = athmac_gmac_unlock, .trylock = athmac_gmac_trylock, .reg_read = athmac_reg_read, .reg_write = athmac_reg_write, .status_changed = athmac_status_changed, .poll = athmac_poll, .set_status = athgmac_set_status, .setup_irq = athmac_setup_irq, .setup_special_hw = wasp_virian_setup_hw, .parent = &avmnet_HW201v2, .num_children = 1, .children = { &HW201v2_ath_switch }, }; avmnet_module_t HW201v2_ath_switch ____cacheline_aligned = { .name = "ar8326", .type = avmnet_modtype_switch, .priv = NULL, .initdata.swi = { .flags = AVMNET_CONFIG_FLAG_IRQ | AVMNET_CONFIG_FLAG_MAC_SUPPORT_FC_ASYM | AVMNET_CONFIG_FLAG_MAC_SUPPORT_FC_SYM, .irq = ATH_MISC_IRQ_ENET_LINK }, .init = avmnet_ar8326_init, .setup = avmnet_ar8326_setup, .exit = avmnet_ar8326_exit, .reg_read = avmnet_s27_rd_phy, .reg_write = avmnet_s27_wr_phy, .lock = avmnet_s27_lock, .unlock = avmnet_s27_unlock, .trylock = avmnet_s27_trylock, .status_changed = avmnet_ar8326_status_changed, .poll = avmnet_ar8326_status_poll, .set_status = avmnet_ar8326_set_status, .setup_irq = avmnet_ar8326_setup_interrupt, .parent = &HW201v2_gmac1, .num_children = 3, .children = { &HW201v2_module_plc_phy, &HW201v2_module_eth0, &HW201v2_module_eth1 } }; avmnet_module_t HW201v2_module_plc_phy ____cacheline_aligned = { .name = "ar803x4", .device_id = &avmnet_hw201v2_avm_device_plc, .type = avmnet_modtype_phy, .priv = NULL, .initdata.phy = { .flags = ( AVMNET_CONFIG_FLAG_MDIOADDR | AVMNET_CONFIG_FLAG_INTERNAL | AVMNET_CONFIG_FLAG_LINKFAIL_TIME | AVMNET_CONFIG_FLAG_PHY_MODE_CONF | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_RX | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_TX ), .mode_conf = ( ADVERTISED_100baseT_Half | ADVERTISED_100baseT_Full | ADVERTISED_Autoneg | ADVERTISED_TP ), .lnkf_time = 1 * HZ, .mdio_addr = 4 }, AR803X_STDFUNCS, .ethtool_ops = AR803X_ETHOPS, .parent = &HW201v2_ath_switch, .num_children = 1, .children = {&HW201v2_module_plc} }; avmnet_module_t HW201v2_module_plc ____cacheline_aligned = { .name = "plc", .device_id = NULL, .type = avmnet_modtype_phy, .priv = NULL, .initdata.phy = { .flags = AVMNET_CONFIG_FLAG_RESET, .reset = 20, }, .init = avmnet_phy_plc_init, .setup = avmnet_phy_plc_setup, .exit = avmnet_phy_plc_exit, .reg_read = avmnet_phy_plc_reg_read, .reg_write = avmnet_phy_plc_reg_write, .lock = avmnet_phy_plc_lock, .unlock = avmnet_phy_plc_unlock, .trylock = avmnet_phy_plc_trylock, .status_changed = avmnet_phy_plc_status_changed, .set_status = avmnet_phy_plc_set_status, .poll = avmnet_phy_plc_poll, .setup_irq = avmnet_phy_plc_setup_irq, .powerup = avmnet_phy_plc_powerup, .powerdown = avmnet_phy_plc_powerdown, .ethtool_ops = {}, .parent = &HW201v2_module_plc_phy, .num_children = 0, .children = {} }; avmnet_module_t HW201v2_module_eth0 ____cacheline_aligned = { .name = "ar803x1", .device_id = &avmnet_hw201v2_avm_device_eth1, .type = avmnet_modtype_phy, .priv = NULL, .initdata.phy = { .flags = ( AVMNET_CONFIG_FLAG_MDIOADDR | AVMNET_CONFIG_FLAG_INTERNAL | AVMNET_CONFIG_FLAG_LINKFAIL_TIME | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_RX | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_TX ), .lnkf_time = 1 * HZ, .mdio_addr = 2 }, AR803X_STDFUNCS, .ethtool_ops = AR803X_ETHOPS, .parent = &HW201v2_ath_switch, .num_children = 0, .children = {} }; avmnet_module_t HW201v2_module_eth1 ____cacheline_aligned = { .name = "ar803x0", .device_id = &avmnet_hw201v2_avm_device_eth0, .type = avmnet_modtype_phy, .priv = NULL, .initdata.phy = { .flags = ( AVMNET_CONFIG_FLAG_MDIOADDR | AVMNET_CONFIG_FLAG_INTERNAL | AVMNET_CONFIG_FLAG_LINKFAIL_TIME | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_RX | AVMNET_CONFIG_FLAG_DEFAULT_EN_FC_TX ), .lnkf_time = 1 * HZ, .mdio_addr = 1 }, AR803X_STDFUNCS, .ethtool_ops = AR803X_ETHOPS, .parent = &HW201v2_ath_switch, .num_children = 0, .children = {} }; #endif