Lines Matching full:db

119 static int dm9051_set_reg(struct board_info *db, unsigned int reg, unsigned int val)  in dm9051_set_reg()  argument
123 ret = regmap_write(db->regmap_dm, reg, val); in dm9051_set_reg()
125 netif_err(db, drv, db->ndev, "%s: error %d set reg %02x\n", in dm9051_set_reg()
130 static int dm9051_update_bits(struct board_info *db, unsigned int reg, unsigned int mask, in dm9051_update_bits() argument
135 ret = regmap_update_bits(db->regmap_dm, reg, mask, val); in dm9051_update_bits()
137 netif_err(db, drv, db->ndev, "%s: error %d update bits reg %02x\n", in dm9051_update_bits()
144 static int dm9051_dumpblk(struct board_info *db, u8 reg, size_t count) in dm9051_dumpblk() argument
146 struct net_device *ndev = db->ndev; in dm9051_dumpblk()
155 ret = regmap_read(db->regmap_dm, reg, &rb); in dm9051_dumpblk()
157 netif_err(db, drv, ndev, "%s: error %d dumping read reg %02x\n", in dm9051_dumpblk()
166 static int dm9051_set_regs(struct board_info *db, unsigned int reg, const void *val, in dm9051_set_regs() argument
171 ret = regmap_bulk_write(db->regmap_dmbulk, reg, val, val_count); in dm9051_set_regs()
173 netif_err(db, drv, db->ndev, "%s: error %d bulk writing regs %02x\n", in dm9051_set_regs()
178 static int dm9051_get_regs(struct board_info *db, unsigned int reg, void *val, in dm9051_get_regs() argument
183 ret = regmap_bulk_read(db->regmap_dmbulk, reg, val, val_count); in dm9051_get_regs()
185 netif_err(db, drv, db->ndev, "%s: error %d bulk reading regs %02x\n", in dm9051_get_regs()
190 static int dm9051_write_mem(struct board_info *db, unsigned int reg, const void *buff, in dm9051_write_mem() argument
195 ret = regmap_noinc_write(db->regmap_dm, reg, buff, len); in dm9051_write_mem()
197 netif_err(db, drv, db->ndev, "%s: error %d noinc writing regs %02x\n", in dm9051_write_mem()
202 static int dm9051_read_mem(struct board_info *db, unsigned int reg, void *buff, in dm9051_read_mem() argument
207 ret = regmap_noinc_read(db->regmap_dm, reg, buff, len); in dm9051_read_mem()
209 netif_err(db, drv, db->ndev, "%s: error %d noinc reading regs %02x\n", in dm9051_read_mem()
217 static int dm9051_nsr_poll(struct board_info *db) in dm9051_nsr_poll() argument
222 ret = regmap_read_poll_timeout(db->regmap_dm, DM9051_NSR, mval, in dm9051_nsr_poll()
225 netdev_err(db->ndev, "timeout in checking for tx end\n"); in dm9051_nsr_poll()
229 static int dm9051_epcr_poll(struct board_info *db) in dm9051_epcr_poll() argument
234 ret = regmap_read_poll_timeout(db->regmap_dm, DM9051_EPCR, mval, in dm9051_epcr_poll()
237 netdev_err(db->ndev, "eeprom/phy in processing get timeout\n"); in dm9051_epcr_poll()
241 static int dm9051_irq_flag(struct board_info *db) in dm9051_irq_flag() argument
243 struct spi_device *spi = db->spidev; in dm9051_irq_flag()
252 static unsigned int dm9051_intcr_value(struct board_info *db) in dm9051_intcr_value() argument
254 return (dm9051_irq_flag(db) == IRQF_TRIGGER_LOW) ? in dm9051_intcr_value()
258 static int dm9051_set_fcr(struct board_info *db) in dm9051_set_fcr() argument
262 if (db->pause.rx_pause) in dm9051_set_fcr()
264 if (db->pause.tx_pause) in dm9051_set_fcr()
267 return dm9051_set_reg(db, DM9051_FCR, fcr); in dm9051_set_fcr()
270 static int dm9051_set_recv(struct board_info *db) in dm9051_set_recv() argument
274 ret = dm9051_set_regs(db, DM9051_MAR, db->rctl.hash_table, sizeof(db->rctl.hash_table)); in dm9051_set_recv()
278 return dm9051_set_reg(db, DM9051_RCR, db->rctl.rcr_all); /* enable rx */ in dm9051_set_recv()
281 static int dm9051_core_reset(struct board_info *db) in dm9051_core_reset() argument
285 db->bc.fifo_rst_counter++; in dm9051_core_reset()
287 ret = regmap_write(db->regmap_dm, DM9051_NCR, NCR_RST); /* NCR reset */ in dm9051_core_reset()
290 ret = regmap_write(db->regmap_dm, DM9051_MBNDRY, MBNDRY_BYTE); /* MemBound */ in dm9051_core_reset()
293 ret = regmap_write(db->regmap_dm, DM9051_PPCR, PPCR_PAUSE_COUNT); /* Pause Count */ in dm9051_core_reset()
296 ret = regmap_write(db->regmap_dm, DM9051_LMCR, db->lcr_all); /* LEDMode1 */ in dm9051_core_reset()
300 return dm9051_set_reg(db, DM9051_INTCR, dm9051_intcr_value(db)); in dm9051_core_reset()
303 static int dm9051_update_fcr(struct board_info *db) in dm9051_update_fcr() argument
307 if (db->pause.rx_pause) in dm9051_update_fcr()
309 if (db->pause.tx_pause) in dm9051_update_fcr()
312 return dm9051_update_bits(db, DM9051_FCR, FCR_RXTX_BITS, fcr); in dm9051_update_fcr()
315 static int dm9051_disable_interrupt(struct board_info *db) in dm9051_disable_interrupt() argument
317 return dm9051_set_reg(db, DM9051_IMR, IMR_PAR); /* disable int */ in dm9051_disable_interrupt()
320 static int dm9051_enable_interrupt(struct board_info *db) in dm9051_enable_interrupt() argument
322 return dm9051_set_reg(db, DM9051_IMR, db->imr_all); /* enable int */ in dm9051_enable_interrupt()
325 static int dm9051_stop_mrcmd(struct board_info *db) in dm9051_stop_mrcmd() argument
327 return dm9051_set_reg(db, DM9051_ISR, ISR_STOP_MRCMD); /* to stop mrcmd */ in dm9051_stop_mrcmd()
330 static int dm9051_clear_interrupt(struct board_info *db) in dm9051_clear_interrupt() argument
332 return dm9051_update_bits(db, DM9051_ISR, ISR_CLR_INT, ISR_CLR_INT); in dm9051_clear_interrupt()
335 static int dm9051_eeprom_read(struct board_info *db, int offset, u8 *to) in dm9051_eeprom_read() argument
339 ret = regmap_write(db->regmap_dm, DM9051_EPAR, offset); in dm9051_eeprom_read()
343 ret = regmap_write(db->regmap_dm, DM9051_EPCR, EPCR_ERPRR); in dm9051_eeprom_read()
347 ret = dm9051_epcr_poll(db); in dm9051_eeprom_read()
351 ret = regmap_write(db->regmap_dm, DM9051_EPCR, 0); in dm9051_eeprom_read()
355 return regmap_bulk_read(db->regmap_dmbulk, DM9051_EPDRL, to, 2); in dm9051_eeprom_read()
358 static int dm9051_eeprom_write(struct board_info *db, int offset, u8 *data) in dm9051_eeprom_write() argument
362 ret = regmap_write(db->regmap_dm, DM9051_EPAR, offset); in dm9051_eeprom_write()
366 ret = regmap_bulk_write(db->regmap_dmbulk, DM9051_EPDRL, data, 2); in dm9051_eeprom_write()
370 ret = regmap_write(db->regmap_dm, DM9051_EPCR, EPCR_WEP | EPCR_ERPRW); in dm9051_eeprom_write()
374 ret = dm9051_epcr_poll(db); in dm9051_eeprom_write()
378 return regmap_write(db->regmap_dm, DM9051_EPCR, 0); in dm9051_eeprom_write()
383 struct board_info *db = context; in dm9051_phyread() local
386 ret = regmap_write(db->regmap_dm, DM9051_EPAR, DM9051_PHY | reg); in dm9051_phyread()
390 ret = regmap_write(db->regmap_dm, DM9051_EPCR, EPCR_ERPRR | EPCR_EPOS); in dm9051_phyread()
394 ret = dm9051_epcr_poll(db); in dm9051_phyread()
398 ret = regmap_write(db->regmap_dm, DM9051_EPCR, 0); in dm9051_phyread()
406 return regmap_bulk_read(db->regmap_dmbulk, DM9051_EPDRL, val, 2); in dm9051_phyread()
411 struct board_info *db = context; in dm9051_phywrite() local
414 ret = regmap_write(db->regmap_dm, DM9051_EPAR, DM9051_PHY | reg); in dm9051_phywrite()
418 ret = regmap_bulk_write(db->regmap_dmbulk, DM9051_EPDRL, &val, 2); in dm9051_phywrite()
422 ret = regmap_write(db->regmap_dm, DM9051_EPCR, EPCR_EPOS | EPCR_ERPRW); in dm9051_phywrite()
426 ret = dm9051_epcr_poll(db); in dm9051_phywrite()
430 return regmap_write(db->regmap_dm, DM9051_EPCR, 0); in dm9051_phywrite()
435 struct board_info *db = bus->priv; in dm9051_mdio_read() local
440 ret = dm9051_phyread(db, regnum, &val); in dm9051_mdio_read()
450 struct board_info *db = bus->priv; in dm9051_mdio_write() local
453 return dm9051_phywrite(db, regnum, val); in dm9051_mdio_write()
460 struct board_info *db = dbcontext; in dm9051_reg_lock_mutex() local
462 mutex_lock(&db->reg_mutex); in dm9051_reg_lock_mutex()
467 struct board_info *db = dbcontext; in dm9051_reg_unlock_mutex() local
469 mutex_unlock(&db->reg_mutex); in dm9051_reg_unlock_mutex()
500 static int dm9051_map_init(struct spi_device *spi, struct board_info *db) in dm9051_map_init() argument
506 regconfigdm.lock_arg = db; in dm9051_map_init()
507 db->regmap_dm = devm_regmap_init_spi(db->spidev, &regconfigdm); in dm9051_map_init()
508 if (IS_ERR(db->regmap_dm)) in dm9051_map_init()
509 return PTR_ERR(db->regmap_dm); in dm9051_map_init()
511 regconfigdmbulk.lock_arg = db; in dm9051_map_init()
512 db->regmap_dmbulk = devm_regmap_init_spi(db->spidev, &regconfigdmbulk); in dm9051_map_init()
513 if (IS_ERR(db->regmap_dmbulk)) in dm9051_map_init()
514 return PTR_ERR(db->regmap_dmbulk); in dm9051_map_init()
519 static int dm9051_map_chipid(struct board_info *db) in dm9051_map_chipid() argument
521 struct device *dev = &db->spidev->dev; in dm9051_map_chipid()
526 ret = dm9051_get_regs(db, DM9051_VIDL, buff, sizeof(buff)); in dm9051_map_chipid()
542 static int dm9051_map_etherdev_par(struct net_device *ndev, struct board_info *db) in dm9051_map_etherdev_par() argument
547 ret = dm9051_get_regs(db, DM9051_PAR, addr, sizeof(addr)); in dm9051_map_etherdev_par()
554 ret = dm9051_set_regs(db, DM9051_PAR, ndev->dev_addr, sizeof(ndev->dev_addr)); in dm9051_map_etherdev_par()
558 dev_dbg(&db->spidev->dev, "Use random MAC address\n"); in dm9051_map_etherdev_par()
575 struct board_info *db = to_dm9051_board(ndev); in dm9051_set_msglevel() local
577 db->msg_enable = value; in dm9051_set_msglevel()
582 struct board_info *db = to_dm9051_board(ndev); in dm9051_get_msglevel() local
584 return db->msg_enable; in dm9051_get_msglevel()
595 struct board_info *db = to_dm9051_board(ndev); in dm9051_get_eeprom() local
606 ret = dm9051_eeprom_read(db, (offset + i) / 2, data + i); in dm9051_get_eeprom()
616 struct board_info *db = to_dm9051_board(ndev); in dm9051_set_eeprom() local
628 ret = dm9051_eeprom_write(db, (offset + i) / 2, data + i); in dm9051_set_eeprom()
638 struct board_info *db = to_dm9051_board(ndev); in dm9051_get_pauseparam() local
640 *pause = db->pause; in dm9051_get_pauseparam()
646 struct board_info *db = to_dm9051_board(ndev); in dm9051_set_pauseparam() local
648 db->pause = *pause; in dm9051_set_pauseparam()
651 return dm9051_update_fcr(db); in dm9051_set_pauseparam()
653 phy_set_sym_pause(db->phydev, pause->rx_pause, pause->tx_pause, in dm9051_set_pauseparam()
655 phy_start_aneg(db->phydev); in dm9051_set_pauseparam()
674 static int dm9051_all_start(struct board_info *db) in dm9051_all_start() argument
680 ret = dm9051_set_reg(db, DM9051_GPR, 0); in dm9051_all_start()
689 ret = dm9051_core_reset(db); in dm9051_all_start()
693 return dm9051_enable_interrupt(db); in dm9051_all_start()
696 static int dm9051_all_stop(struct board_info *db) in dm9051_all_stop() argument
703 ret = dm9051_set_reg(db, DM9051_GPR, GPR_PHY_OFF); in dm9051_all_stop()
707 return dm9051_set_reg(db, DM9051_RCR, RCR_RX_DISABLE); in dm9051_all_stop()
712 static int dm9051_all_restart(struct board_info *db) in dm9051_all_restart() argument
714 struct net_device *ndev = db->ndev; in dm9051_all_restart()
717 ret = dm9051_core_reset(db); in dm9051_all_restart()
721 ret = dm9051_enable_interrupt(db); in dm9051_all_restart()
726 db->bc.status_err_counter + db->bc.large_err_counter, in dm9051_all_restart()
727 db->bc.fifo_rst_counter); in dm9051_all_restart()
729 ret = dm9051_set_recv(db); in dm9051_all_restart()
733 return dm9051_set_fcr(db); in dm9051_all_restart()
742 static int dm9051_loop_rx(struct board_info *db) in dm9051_loop_rx() argument
744 struct net_device *ndev = db->ndev; in dm9051_loop_rx()
752 ret = dm9051_read_mem(db, DM_SPI_MRCMDX, &rxbyte, 2); in dm9051_loop_rx()
759 ret = dm9051_read_mem(db, DM_SPI_MRCMD, &db->rxhdr, DM_RXHDR_SIZE); in dm9051_loop_rx()
763 ret = dm9051_stop_mrcmd(db); in dm9051_loop_rx()
767 rxlen = le16_to_cpu(db->rxhdr.rxlen); in dm9051_loop_rx()
768 if (db->rxhdr.status & RSR_ERR_BITS || rxlen > DM9051_PKT_MAX) { in dm9051_loop_rx()
770 db->rxhdr.headbyte); in dm9051_loop_rx()
772 if (db->rxhdr.status & RSR_ERR_BITS) { in dm9051_loop_rx()
773 db->bc.status_err_counter++; in dm9051_loop_rx()
775 db->rxhdr.status); in dm9051_loop_rx()
777 db->bc.large_err_counter++; in dm9051_loop_rx()
781 return dm9051_all_restart(db); in dm9051_loop_rx()
786 ret = dm9051_dumpblk(db, DM_SPI_MRCMD, rxlen); in dm9051_loop_rx()
793 ret = dm9051_read_mem(db, DM_SPI_MRCMD, rdptr, rxlen); in dm9051_loop_rx()
795 db->bc.rx_err_counter++; in dm9051_loop_rx()
800 ret = dm9051_stop_mrcmd(db); in dm9051_loop_rx()
806 skb->protocol = eth_type_trans(skb, db->ndev); in dm9051_loop_rx()
807 if (db->ndev->features & NETIF_F_RXCSUM) in dm9051_loop_rx()
810 db->ndev->stats.rx_bytes += rxlen; in dm9051_loop_rx()
811 db->ndev->stats.rx_packets++; in dm9051_loop_rx()
823 static int dm9051_single_tx(struct board_info *db, u8 *buff, unsigned int len) in dm9051_single_tx() argument
827 ret = dm9051_nsr_poll(db); in dm9051_single_tx()
831 ret = dm9051_write_mem(db, DM_SPI_MWCMD, buff, len); in dm9051_single_tx()
835 ret = dm9051_set_regs(db, DM9051_TXPLL, &len, 2); in dm9051_single_tx()
839 return dm9051_set_reg(db, DM9051_TCR, TCR_TXREQ); in dm9051_single_tx()
842 static int dm9051_loop_tx(struct board_info *db) in dm9051_loop_tx() argument
844 struct net_device *ndev = db->ndev; in dm9051_loop_tx()
848 while (!skb_queue_empty(&db->txq)) { in dm9051_loop_tx()
852 skb = skb_dequeue(&db->txq); in dm9051_loop_tx()
855 ret = dm9051_single_tx(db, skb->data, skb->len); in dm9051_loop_tx()
859 db->bc.tx_err_counter++; in dm9051_loop_tx()
867 (skb_queue_len(&db->txq) < DM9051_TX_QUE_LO_WATER)) in dm9051_loop_tx()
876 struct board_info *db = pw; in dm9051_rx_threaded_irq() local
879 mutex_lock(&db->spi_lockm); in dm9051_rx_threaded_irq()
881 result = dm9051_disable_interrupt(db); in dm9051_rx_threaded_irq()
885 result = dm9051_clear_interrupt(db); in dm9051_rx_threaded_irq()
890 result = dm9051_loop_rx(db); /* threaded irq rx */ in dm9051_rx_threaded_irq()
893 result_tx = dm9051_loop_tx(db); /* more tx better performance */ in dm9051_rx_threaded_irq()
898 dm9051_enable_interrupt(db); in dm9051_rx_threaded_irq()
903 mutex_unlock(&db->spi_lockm); in dm9051_rx_threaded_irq()
910 struct board_info *db = container_of(work, struct board_info, tx_work); in dm9051_tx_delay() local
913 mutex_lock(&db->spi_lockm); in dm9051_tx_delay()
915 result = dm9051_loop_tx(db); in dm9051_tx_delay()
917 netdev_err(db->ndev, "transmit packet error\n"); in dm9051_tx_delay()
919 mutex_unlock(&db->spi_lockm); in dm9051_tx_delay()
924 struct board_info *db = container_of(work, struct board_info, rxctrl_work); in dm9051_rxctl_delay() local
925 struct net_device *ndev = db->ndev; in dm9051_rxctl_delay()
928 mutex_lock(&db->spi_lockm); in dm9051_rxctl_delay()
930 result = dm9051_set_regs(db, DM9051_PAR, ndev->dev_addr, sizeof(ndev->dev_addr)); in dm9051_rxctl_delay()
934 dm9051_set_recv(db); in dm9051_rxctl_delay()
939 mutex_unlock(&db->spi_lockm); in dm9051_rxctl_delay()
948 struct board_info *db = to_dm9051_board(ndev); in dm9051_open() local
949 struct spi_device *spi = db->spidev; in dm9051_open()
952 db->imr_all = IMR_PAR | IMR_PRM; in dm9051_open()
953 db->lcr_all = LMCR_MODE1; in dm9051_open()
954 db->rctl.rcr_all = RCR_DIS_LONG | RCR_DIS_CRC | RCR_RXEN; in dm9051_open()
955 memset(db->rctl.hash_table, 0, sizeof(db->rctl.hash_table)); in dm9051_open()
959 dm9051_irq_flag(db) | IRQF_ONESHOT, in dm9051_open()
960 ndev->name, db); in dm9051_open()
966 phy_support_sym_pause(db->phydev); in dm9051_open()
967 phy_start(db->phydev); in dm9051_open()
970 db->pause.rx_pause = true; in dm9051_open()
971 db->pause.tx_pause = true; in dm9051_open()
972 db->pause.autoneg = AUTONEG_DISABLE; in dm9051_open()
974 if (db->phydev->autoneg) in dm9051_open()
975 db->pause.autoneg = AUTONEG_ENABLE; in dm9051_open()
977 ret = dm9051_all_start(db); in dm9051_open()
979 phy_stop(db->phydev); in dm9051_open()
980 free_irq(spi->irq, db); in dm9051_open()
996 struct board_info *db = to_dm9051_board(ndev); in dm9051_stop() local
999 ret = dm9051_all_stop(db); in dm9051_stop()
1003 flush_work(&db->tx_work); in dm9051_stop()
1004 flush_work(&db->rxctrl_work); in dm9051_stop()
1006 phy_stop(db->phydev); in dm9051_stop()
1008 free_irq(db->spidev->irq, db); in dm9051_stop()
1012 skb_queue_purge(&db->txq); in dm9051_stop()
1021 struct board_info *db = to_dm9051_board(ndev); in dm9051_start_xmit() local
1023 skb_queue_tail(&db->txq, skb); in dm9051_start_xmit()
1024 if (skb_queue_len(&db->txq) > DM9051_TX_QUE_HI_WATER) in dm9051_start_xmit()
1027 schedule_work(&db->tx_work); in dm9051_start_xmit()
1036 struct board_info *db = to_dm9051_board(ndev); in dm9051_set_rx_mode() local
1071 if (memcmp(&db->rctl, &rxctrl, sizeof(rxctrl))) { in dm9051_set_rx_mode()
1072 memcpy(&db->rctl, &rxctrl, sizeof(rxctrl)); in dm9051_set_rx_mode()
1073 schedule_work(&db->rxctrl_work); in dm9051_set_rx_mode()
1081 struct board_info *db = to_dm9051_board(ndev); in dm9051_set_mac_address() local
1089 return dm9051_set_regs(db, DM9051_PAR, ndev->dev_addr, sizeof(ndev->dev_addr)); in dm9051_set_mac_address()
1101 static void dm9051_operation_clear(struct board_info *db) in dm9051_operation_clear() argument
1103 db->bc.status_err_counter = 0; in dm9051_operation_clear()
1104 db->bc.large_err_counter = 0; in dm9051_operation_clear()
1105 db->bc.rx_err_counter = 0; in dm9051_operation_clear()
1106 db->bc.tx_err_counter = 0; in dm9051_operation_clear()
1107 db->bc.fifo_rst_counter = 0; in dm9051_operation_clear()
1110 static int dm9051_mdio_register(struct board_info *db) in dm9051_mdio_register() argument
1112 struct spi_device *spi = db->spidev; in dm9051_mdio_register()
1115 db->mdiobus = devm_mdiobus_alloc(&spi->dev); in dm9051_mdio_register()
1116 if (!db->mdiobus) in dm9051_mdio_register()
1119 db->mdiobus->priv = db; in dm9051_mdio_register()
1120 db->mdiobus->read = dm9051_mdio_read; in dm9051_mdio_register()
1121 db->mdiobus->write = dm9051_mdio_write; in dm9051_mdio_register()
1122 db->mdiobus->name = "dm9051-mdiobus"; in dm9051_mdio_register()
1123 db->mdiobus->phy_mask = (u32)~BIT(1); in dm9051_mdio_register()
1124 db->mdiobus->parent = &spi->dev; in dm9051_mdio_register()
1125 snprintf(db->mdiobus->id, MII_BUS_ID_SIZE, in dm9051_mdio_register()
1128 ret = devm_mdiobus_register(&spi->dev, db->mdiobus); in dm9051_mdio_register()
1137 struct board_info *db = to_dm9051_board(ndev); in dm9051_handle_link_change() local
1139 phy_print_status(db->phydev); in dm9051_handle_link_change()
1144 if (db->phydev->link) { in dm9051_handle_link_change()
1145 if (db->phydev->pause) { in dm9051_handle_link_change()
1146 db->pause.rx_pause = true; in dm9051_handle_link_change()
1147 db->pause.tx_pause = true; in dm9051_handle_link_change()
1149 dm9051_update_fcr(db); in dm9051_handle_link_change()
1155 static int dm9051_phy_connect(struct board_info *db) in dm9051_phy_connect() argument
1160 db->mdiobus->id, DM9051_PHY_ADDR); in dm9051_phy_connect()
1162 db->phydev = phy_connect(db->ndev, phy_id, dm9051_handle_link_change, in dm9051_phy_connect()
1164 if (IS_ERR(db->phydev)) in dm9051_phy_connect()
1165 return PTR_ERR_OR_ZERO(db->phydev); in dm9051_phy_connect()
1173 struct board_info *db; in dm9051_probe() local
1183 db = netdev_priv(ndev); in dm9051_probe()
1185 db->msg_enable = 0; in dm9051_probe()
1186 db->spidev = spi; in dm9051_probe()
1187 db->ndev = ndev; in dm9051_probe()
1192 mutex_init(&db->spi_lockm); in dm9051_probe()
1193 mutex_init(&db->reg_mutex); in dm9051_probe()
1195 INIT_WORK(&db->rxctrl_work, dm9051_rxctl_delay); in dm9051_probe()
1196 INIT_WORK(&db->tx_work, dm9051_tx_delay); in dm9051_probe()
1198 ret = dm9051_map_init(spi, db); in dm9051_probe()
1202 ret = dm9051_map_chipid(db); in dm9051_probe()
1206 ret = dm9051_map_etherdev_par(ndev, db); in dm9051_probe()
1210 ret = dm9051_mdio_register(db); in dm9051_probe()
1214 ret = dm9051_phy_connect(db); in dm9051_probe()
1218 dm9051_operation_clear(db); in dm9051_probe()
1219 skb_queue_head_init(&db->txq); in dm9051_probe()
1223 phy_disconnect(db->phydev); in dm9051_probe()
1234 struct board_info *db = to_dm9051_board(ndev); in dm9051_drv_remove() local
1236 phy_disconnect(db->phydev); in dm9051_drv_remove()