[U-Boot-Users] [PATCH 08/13] SPARC: added SMC91111 driver in and out macros for LEON processors.
Ben Warren
biggerbadderben at gmail.com
Sun Mar 30 06:29:25 CEST 2008
Daniel Hellstrom wrote:
> Hello Wolfgang,
>
> This patch makes SPARC/LEON processors able to read and write
> to the SMC91111 chip using the chip external I/O bus of the memory
> controller. This patchs defines the standard in and out macros
> expected by the SMC9111 driver.
>
> To access that I/O bus one must set up the memory controller
> (MCTRL or FTMCTRL) correctly. It is assumed that the user sets
> up this correctly when the other MCTRL parameters are set up. It
> can be set up from the board configuration header file.
>
> This patch is also available at ftp://ftp.gaisler.com/gaisler.com/u-boot/patches.
>
> Best Regards,
> Daniel Hellstrom
>
> Signed-off-by: Daniel Hellstrom <daniel at gaisler.com>
> ---
> drivers/net/smc91111.h | 74 +++++++++++++++++++++++++++++++++++++++++++++++-
> 1 files changed, 73 insertions(+), 1 deletions(-)
>
> diff --git a/drivers/net/smc91111.h b/drivers/net/smc91111.h
> index 8dcbb3e..6c4af64 100644
> --- a/drivers/net/smc91111.h
> +++ b/drivers/net/smc91111.h
> @@ -176,7 +176,79 @@ typedef unsigned long int dword;
> }; \
> })
>
> -#else /* if not CONFIG_PXA250 */
> +#elif defined(CONFIG_LEON) /* if not CONFIG_PXA250 */
> +
> +#define SMC_LEON_SWAP16(_x_) \
> + ({ word _x = (_x_); ((_x << 8) | (_x >> 8)); })
> +
> +#define SMC_LEON_SWAP32(_x_) \
> + ({ dword _x = (_x_); \
> + ((_x << 24) | \
> + ((0x0000FF00UL & _x) << 8) | \
> + ((0x00FF0000UL & _x) >> 8) | \
> + (_x >> 24)); })
> +
> +#define SMC_inl(r) (SMC_LEON_SWAP32((*(volatile dword *)(SMC_BASE_ADDRESS+((r)<<0)))))
> +#define SMC_inl_nosw(r) ((*(volatile dword *)(SMC_BASE_ADDRESS+((r)<<0))))
> +#define SMC_inw(r) (SMC_LEON_SWAP16((*(volatile word *)(SMC_BASE_ADDRESS+((r)<<0)))))
> +#define SMC_inw_nosw(r) ((*(volatile word *)(SMC_BASE_ADDRESS+((r)<<0))))
> +#define SMC_inb(p) ({ \
> + word ___v = SMC_inw((p) & ~1); \
> + if (p & 1) ___v >>= 8; \
> + else ___v &= 0xff; \
> + ___v; })
> +#define SMC_outl(d,r) (*(volatile dword *)(SMC_BASE_ADDRESS+((r)<<0))=SMC_LEON_SWAP32(d))
> +#define SMC_outl_nosw(d,r) (*(volatile dword *)(SMC_BASE_ADDRESS+((r)<<0))=(d))
> +#define SMC_outw(d,r) (*(volatile word *)(SMC_BASE_ADDRESS+((r)<<0))=SMC_LEON_SWAP16(d))
> +#define SMC_outw_nosw(d,r) (*(volatile word *)(SMC_BASE_ADDRESS+((r)<<0))=(d))
> +#define SMC_outb(d,r) ({ word __d = (byte)(d); \
> + word __w = SMC_inw((r)&~1); \
> + __w &= ((r)&1) ? 0x00FF : 0xFF00; \
> + __w |= ((r)&1) ? __d<<8 : __d; \
> + SMC_outw(__w,(r)&~1); \
> + })
> +#define SMC_outsl(r,b,l) ({ int __i; \
> + dword *__b2; \
> + __b2 = (dword *) b; \
> + for (__i = 0; __i < l; __i++) { \
> + SMC_outl_nosw( *(__b2 + __i), r); \
> + } \
> + })
> +#define SMC_outsw(r,b,l) ({ int __i; \
> + word *__b2; \
> + __b2 = (word *) b; \
> + for (__i = 0; __i < l; __i++) { \
> + SMC_outw_nosw( *(__b2 + __i), r); \
> + } \
> + })
> +#define SMC_insl(r,b,l) ({ int __i ; \
> + dword *__b2; \
> + __b2 = (dword *) b; \
> + for (__i = 0; __i < l; __i++) { \
> + *(__b2 + __i) = SMC_inl_nosw(r); \
> + SMC_inl(0); \
> + }; \
> + })
> +
> +#define SMC_insw(r,b,l) ({ int __i ; \
> + word *__b2; \
> + __b2 = (word *) b; \
> + for (__i = 0; __i < l; __i++) { \
> + *(__b2 + __i) = SMC_inw_nosw(r); \
> + SMC_inw(0); \
> + }; \
> + })
> +
> +#define SMC_insb(r,b,l) ({ int __i ; \
> + byte *__b2; \
> + __b2 = (byte *) b; \
> + for (__i = 0; __i < l; __i++) { \
> + *(__b2 + __i) = SMC_inb(r); \
> + SMC_inb(0); \
> + }; \
> + })
> +
> +#else /* if not CONFIG_PXA250 and not CONFIG_LEON */
>
> #ifndef CONFIG_SMC_USE_IOFUNCS /* these macros don't work on some boards */
> /*
>
I haven't looked at how all the funky macros in this patch are called,
but it's generally considered good form to wrap multi-line macros with
do {...} while(0) in order to avoid compiler issues. I'll NAK the patch
for now based on this.
regards,
Ben
More information about the U-Boot
mailing list