[U-Boot-Users] [PATCH] smc91111 - Add I/O functions, remove environment calls

Paul Ruhland pruhland at microwavedata.com
Tue May 11 18:50:29 CEST 2004


This patch makes the following hanges to the smc91111 driver, detailed 
description(s) follow:

1) adds I/O functions (SMC_inb, SMC_outb, SMC_inw, SMC_outw, SMC_insw, 
SMC_outsw ) since some hardware will not work with the macro I/O (Logic 
LH7A400).

2) backs out/modifies a recent change putting calls to getenv and setenv in 
'smc_get_ethaddr'.

3) restores  CTL_DEFAULT definition to the register default and or's 
CTL_AUTO_RELEASE in smc_reset.

4) removes packet number and ptr register 'saving and restoral'.  You don't 
have to do this unless you're changing these in an interrupt handler.   This 
driver is polled.

5) adds proper handling of tx interrupt status and autorelease

Description:
------------

1) Using the I/O macros on the Logic LH7A400 SDK does not work and puts the 
MAC in an unknown state.  Symptoms being data being shifted on the wire, 
packets being sent twice, MAC unable to free packets.  Receive works just 
fine while all this is going on.

It seems multiple word writes are happening to fast for the SMC while all 
other access modes work fine.  It could be the IO function calls add just 
enough delay to make the SMC happy.  Its not my hardware and our board will 
be different so I didn't want to spend any more time on this.  No code is 
added for boards that don't enable the functions.  This is done by defining 
'CONFIG_SMC_USE_IOFUNCS' in the board config.

2) I don't think there should be calls to environment functions from the 
ethernet driver.

The value being read is already passed into the function in the board info 
structure.  If you haven't set an ethernet address in your environment this 
will be all zeros.  If you have set an address in your environment it will be 
in the board info struct.  If either of these is not true, your board is not 
set up correctly.

I don't want a driver changing my environment, period.  Changing the board 
info ethaddr value is fine but don't touch the environment.

I've modified the code to use the value in board info, and modify that same 
value if needed.

3) Autorelease is NOT the control register default

4) again, this driver is polled not interrupt driven, no need to save/restore 
these registers

5)  Moved tx interrupt status handling to the poll4int function.  If 
autorelease not enabled we only care about  IM_TX_INT and must free packets 
on either success or failure.  If autorelease enabled we have to look for 
IM_TX_EMPTY_INT or IM_TX_INT...the former indicates tx was successfull, the 
latter indicates an error.  In error case the packet must still be freed 
manually.

----- 
Paul Ruhland (pruhland at microwavedata.com)
Software Engineer
Microwave Data Systems, Inc.
Rochester, NY 14620


-------------- next part --------------
A non-text attachment was scrubbed...
Name: u-boot-smc91111.patch
Type: text/x-diff
Size: 5703 bytes
Desc: not available
Url : http://lists.denx.de/pipermail/u-boot/attachments/20040511/f9a6b2ab/attachment.patch 


More information about the U-Boot mailing list