SMSC LAN91C111
[Ethernet]

10/100 MBit Ethernet controller. More...

Collaboration diagram for SMSC LAN91C111:


Modules

 LAN91C111 registers
 SMSC LAN91C111 register definitions.

Functions

void NicRxLanc (void *arg)
 NIC receiver thread.
int LancOutput (NUTDEVICE *dev, NETBUF *nb)
 Send Ethernet packet.
int LancInit (NUTDEVICE *dev)
 Initialize Ethernet hardware.

Variables

NUTDEVICE devSmsc111
 Device information structure.

Detailed Description

10/100 MBit Ethernet controller.

The LAN91C111 chip is used on the Ethernut 2 board.


Function Documentation

NicRxLanc ( void *  arg  ) 

int LancOutput ( NUTDEVICE *  dev,
NETBUF *  nb 
)

Send Ethernet packet.

Parameters:
dev Identifies the device to use.
nb Network buffer structure containing the packet to be sent. The structure must have been allocated by a previous call NutNetBufAlloc().
Returns:
0 on success, -1 in case of any errors.

Definition at line 1261 of file lanc111.c.

References NICINFO::ni_tx_packets, NutEventPost(), and NutEventWait().

int LancInit ( NUTDEVICE *  dev  ) 

Initialize Ethernet hardware.

Resets the LAN91C111 Ethernet controller, initializes all required hardware registers and starts a background thread for incoming Ethernet traffic.

Applications should do not directly call this function. It is automatically executed during during device registration by NutRegisterDevice().

If the network configuration hasn't been set by the application before registering the specified device, this function will call NutNetLoadConfig() to get the MAC address.

Parameters:
dev Identifies the device to initialize.

Definition at line 1310 of file lanc111.c.

References cbi, LANC111_SIGNAL, LANC111_SIGNAL_IRQ, memset(), NicRxLanc(), NUT_THREAD_LANCRXSTACK, NUT_THREAD_STACK_ADD, NUT_THREAD_STACK_MULT, NutRegisterIrqHandler(), and NutThreadCreate().


Variable Documentation

NUTDEVICE devSmsc111

Initial value:

 {
    0,                          
    {'e', 't', 'h', '0', 0, 0, 0, 0, 0},        
    IFTYP_NET,                  
    0,                          
    0,                          
    &ifn_eth0,                  
    &dcb_eth0,                  
    LancInit,                   
    0,                          
    0,                          
    0,                          
    0,                          
    0,                          
    0,                          
    0                           
}
Device information structure.

A pointer to this structure must be passed to NutRegisterDevice() to bind this Ethernet device driver to the Nut/OS kernel. An application may then call NutNetIfConfig() with the name eth0 of this driver to initialize the network interface.

Definition at line 1364 of file lanc111.c.


© 2000-2007 by egnite Software GmbH - visit http://www.ethernut.de/