| DM9000 Network driver | 
 | ===================== | 
 |  | 
 | Copyright 2008 Simtec Electronics, | 
 | 	  Ben Dooks <ben@simtec.co.uk> <ben-linux@fluff.org> | 
 |  | 
 |  | 
 | Introduction | 
 | ------------ | 
 |  | 
 | This file describes how to use the DM9000 platform-device based network driver | 
 | that is contained in the files drivers/net/dm9000.c and drivers/net/dm9000.h. | 
 |  | 
 | The driver supports three DM9000 variants, the DM9000E which is the first chip | 
 | supported as well as the newer DM9000A and DM9000B devices. It is currently | 
 | maintained and tested by Ben Dooks, who should be CC: to any patches for this | 
 | driver. | 
 |  | 
 |  | 
 | Defining the platform device | 
 | ---------------------------- | 
 |  | 
 | The minimum set of resources attached to the platform device are as follows: | 
 |  | 
 |     1) The physical address of the address register | 
 |     2) The physical address of the data register | 
 |     3) The IRQ line the device's interrupt pin is connected to. | 
 |  | 
 | These resources should be specified in that order, as the ordering of the | 
 | two address regions is important (the driver expects these to be address | 
 | and then data). | 
 |  | 
 | An example from arch/arm/mach-s3c2410/mach-bast.c is: | 
 |  | 
 | static struct resource bast_dm9k_resource[] = { | 
 | 	[0] = { | 
 | 		.start = S3C2410_CS5 + BAST_PA_DM9000, | 
 | 		.end   = S3C2410_CS5 + BAST_PA_DM9000 + 3, | 
 | 		.flags = IORESOURCE_MEM, | 
 | 	}, | 
 | 	[1] = { | 
 | 		.start = S3C2410_CS5 + BAST_PA_DM9000 + 0x40, | 
 | 		.end   = S3C2410_CS5 + BAST_PA_DM9000 + 0x40 + 0x3f, | 
 | 		.flags = IORESOURCE_MEM, | 
 | 	}, | 
 | 	[2] = { | 
 | 		.start = IRQ_DM9000, | 
 | 		.end   = IRQ_DM9000, | 
 | 		.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL, | 
 | 	} | 
 | }; | 
 |  | 
 | static struct platform_device bast_device_dm9k = { | 
 | 	.name		= "dm9000", | 
 | 	.id		= 0, | 
 | 	.num_resources	= ARRAY_SIZE(bast_dm9k_resource), | 
 | 	.resource	= bast_dm9k_resource, | 
 | }; | 
 |  | 
 | Note the setting of the IRQ trigger flag in bast_dm9k_resource[2].flags, | 
 | as this will generate a warning if it is not present. The trigger from | 
 | the flags field will be passed to request_irq() when registering the IRQ | 
 | handler to ensure that the IRQ is setup correctly. | 
 |  | 
 | This shows a typical platform device, without the optional configuration | 
 | platform data supplied. The next example uses the same resources, but adds | 
 | the optional platform data to pass extra configuration data: | 
 |  | 
 | static struct dm9000_plat_data bast_dm9k_platdata = { | 
 | 	.flags		= DM9000_PLATF_16BITONLY, | 
 | }; | 
 |  | 
 | static struct platform_device bast_device_dm9k = { | 
 | 	.name		= "dm9000", | 
 | 	.id		= 0, | 
 | 	.num_resources	= ARRAY_SIZE(bast_dm9k_resource), | 
 | 	.resource	= bast_dm9k_resource, | 
 | 	.dev		= { | 
 | 		.platform_data = &bast_dm9k_platdata, | 
 | 	} | 
 | }; | 
 |  | 
 | The platform data is defined in include/linux/dm9000.h and described below. | 
 |  | 
 |  | 
 | Platform data | 
 | ------------- | 
 |  | 
 | Extra platform data for the DM9000 can describe the IO bus width to the | 
 | device, whether or not an external PHY is attached to the device and | 
 | the availability of an external configuration EEPROM. | 
 |  | 
 | The flags for the platform data .flags field are as follows: | 
 |  | 
 | DM9000_PLATF_8BITONLY | 
 |  | 
 | 	The IO should be done with 8bit operations. | 
 |  | 
 | DM9000_PLATF_16BITONLY | 
 |  | 
 | 	The IO should be done with 16bit operations. | 
 |  | 
 | DM9000_PLATF_32BITONLY | 
 |  | 
 | 	The IO should be done with 32bit operations. | 
 |  | 
 | DM9000_PLATF_EXT_PHY | 
 |  | 
 | 	The chip is connected to an external PHY. | 
 |  | 
 | DM9000_PLATF_NO_EEPROM | 
 |  | 
 | 	This can be used to signify that the board does not have an | 
 | 	EEPROM, or that the EEPROM should be hidden from the user. | 
 |  | 
 | DM9000_PLATF_SIMPLE_PHY | 
 |  | 
 | 	Switch to using the simpler PHY polling method which does not | 
 | 	try and read the MII PHY state regularly. This is only available | 
 | 	when using the internal PHY. See the section on link state polling | 
 | 	for more information. | 
 |  | 
 | 	The config symbol DM9000_FORCE_SIMPLE_PHY_POLL, Kconfig entry | 
 | 	"Force simple NSR based PHY polling" allows this flag to be | 
 | 	forced on at build time. | 
 |  | 
 |  | 
 | PHY Link state polling | 
 | ---------------------- | 
 |  | 
 | The driver keeps track of the link state and informs the network core | 
 | about link (carrier) availability. This is managed by several methods | 
 | depending on the version of the chip and on which PHY is being used. | 
 |  | 
 | For the internal PHY, the original (and currently default) method is | 
 | to read the MII state, either when the status changes if we have the | 
 | necessary interrupt support in the chip or every two seconds via a | 
 | periodic timer. | 
 |  | 
 | To reduce the overhead for the internal PHY, there is now the option | 
 | of using the DM9000_FORCE_SIMPLE_PHY_POLL config, or DM9000_PLATF_SIMPLE_PHY | 
 | platform data option to read the summary information without the | 
 | expensive MII accesses. This method is faster, but does not print | 
 | as much information. | 
 |  | 
 | When using an external PHY, the driver currently has to poll the MII | 
 | link status as there is no method for getting an interrupt on link change. | 
 |  | 
 |  | 
 | DM9000A / DM9000B | 
 | ----------------- | 
 |  | 
 | These chips are functionally similar to the DM9000E and are supported easily | 
 | by the same driver. The features are: | 
 |  | 
 |    1) Interrupt on internal PHY state change. This means that the periodic | 
 |       polling of the PHY status may be disabled on these devices when using | 
 |       the internal PHY. | 
 |  | 
 |    2) TCP/UDP checksum offloading, which the driver does not currently support. | 
 |  | 
 |  | 
 | ethtool | 
 | ------- | 
 |  | 
 | The driver supports the ethtool interface for access to the driver | 
 | state information, the PHY state and the EEPROM. |