Hi,

On Wed, Apr 06, 2011 at 15:02:22, Ran Shalit wrote:
>  
> 
>       It seems that currently both atmel & davinci boards supports only 1 spi 
> instance at a time.
>       
>       In order to support different spi instances,
>       In case of atmel declare SPIx_BASE as required & set 
> CONFIG_DEFAULT_SPI_BUS to required bus
>       In case of davinci set CONFIG_SYS_SPI_BASE to base address of required 
> spi instance
>       
>       Also, spi_cs_is_valid() function needs to be updated to support 
> different spi instances. spi_cs_is_valid() function is board dependednt.
>       
>       Hope this helps.
>       
>       Regards,
>       Gururaja
>       
> 
> 
>  
> Hi Gururaja,
>  
> It seems that the implementation limit the validity only for bus==0.
> This means that trying other bus(=spi port ?)  will fail even if its not at 
> the same time. In addition to that the CPU's data sheet make no limit.
>  
> Best Regards,
> Ran
> 

Don't top post.


Currenly davinci spi driver only allows (bus == 0) to pass which means spi0. So 
if you want to support other or many spi port at once, then

1. you need to change spi_cs_is_valid() to check for various bus values &
2. validate the bus argument to spi_setup_slave(). may be using a switch as in 
case of atmel. 
 
from 

ds->regs = (struct davinci_spi_regs *)CONFIG_SYS_SPI_BASE;

to 

struct davinci_spi_regs *regs;

switch (bus) {
        case 0:
                regs = (struct davinci_spi_regs *)CONFIG_SYS_SPI0_BASE;
                break;
        case 1:
                regs = (struct davinci_spi_regs *)CONFIG_SYS_SPI1_BASE;
                break;
                 ...
                 ...
        default:
                return NULL;
        }

ds->regs = regs;

Regards
Gururaja
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to