**This is an old revision of the document!** ----
<code c> static struct net_device_operations rtl8169_operations = { .open = rtl8169_open, .transmit = rtl8169_transmit, .poll = rtl8169_poll, .close = rtl8169_close, .irq = rtl8169_irq, }; struct pci_driver rtl8169_driver __pci_driver = { .ids = rtl8169_nics, .id_count = ( sizeof ( rtl8169_nics ) / sizeof ( rtl8169_nics[0] ) ), .probe = rtl8169_probe, .remove = rtl8169_remove, }; rtl8169_probe { alloc_etherdev netdev_init pci_set_drvdata netdev_priv memset adjust_pci_Device rtl8169_irq_mask_and_ack rtl_soft_reset netdev_priv rtl8169_get_mac_version rtl8169_init_phy rtl_hw_phy_config () netdev_priv rtlXXXXX_X_hw_phy_config pci_write_config_byte mdio_write rtl8169_phy_reset phy_reset_enable phy_reset_pending rtl8169_set_speed netdev_priv set_speed netdev_link_up } rtl8169_open { netdev_priv rtl8169_setup_tx_resources malloc_dma memset rtl8169_setup_rx_resources malloc_dma memset rtl8169_refill_rx_ring alloc_iob rtl8169_populate_rx_descriptor memset virt_to_bus rtl_hw_start rtl_soft_reset netdev_priv } rtl8169_poll netdev_priv rtl8169_process_tx_packets netdev_tx_complete memset rtl8169_process_rx_packets (netdev_rx_err) iob_put netdev_rx memset rtl8169_refill_rx_ring rtl8169_populate_rx_descriptor memset virt_to_bus } } } } rtl8169_transmit netdev_priv iob_len virt_to_bus } rtl8169_close netdev_priv rtl8169_hw_reset rtl8169_irq_mask_and_ack rtl8169_free_tx_resources free_dma rtl8169_free_rx_resources free_dma free_iob } rtl8169_remove pci_Get_drvdata netdev_priv rtl8169_hw_reset rtl8169_irq_mask_and_ack unregister_netdev netdev_nullify netdeV_put } rtl8169_irq netdev_priv rtl8169_irq_disable rtl8169_irq_mask_and_ack rtl8169_irq_enable } </code>