From: Dirk Behme <dirk.behme@googlemail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] Remove board specific code from ENC28J60 network driver?
Date: Mon, 21 Dec 2009 09:26:06 +0100 [thread overview]
Message-ID: <4B2F311E.8020905@googlemail.com> (raw)
In-Reply-To: <200912201505.51636.vapier@gentoo.org>
On 20.12.2009 21:05, Mike Frysinger wrote:
> On Sunday 20 December 2009 14:30:35 Dirk Behme wrote:
>> For TI OMAP3 Beagle based Zippy expansion board from TinCanTools [1]
>> I'm currently looking into reusing spi based ENC28J60 network driver
>>
>> drivers/net/enc28j60.c
>>
>> It seems to me that it uses LPC2292 specific macros
>>
>> IO1CLR, IO1SET and IO1DIR
>>
>> These macros are defined in
>>
>> asm-arm/arch-lpc2292/lpc2292_registers.h
>
> this is why we didnt bother trying to get this part working on Blackfin boards
> under u-boot. it works fine for us under Linux,
Similar situation with Beagle and Zippy.
> but the u-boot driver is a
> joke.
:(
>> From enc28j60.c:
>>
>> ...
>> #define enc_enable() PUT32(IO1CLR, ENC_SPI_SLAVE_CS)
>> #define enc_disable() PUT32(IO1SET, ENC_SPI_SLAVE_CS)
>> ...
>>
>> ...
>> /* configure GPIO */
>> (*((volatile unsigned long *) IO1DIR)) |= ENC_SPI_SLAVE_CS;
>> (*((volatile unsigned long *) IO1DIR)) |= ENC_RESET;
>>
>> /* CS and RESET active low */
>> PUT32 (IO1SET, ENC_SPI_SLAVE_CS);
>> PUT32 (IO1SET, ENC_RESET);
>> ...
>>
>> Anybody with an idea how to move this code to some (LPC2292?) board
>> specific files to make enc28j60.c more generic to be able to reuse it
>> on other boards?
>
> unless the maintainers of the LPC2292 board are willing to help
Any idea who are the LPC2292 board maintainers? I couldn't find a
LPC2292 entry in MAINTAINERS. Initial check in of enc28j60.c seems to
be done by Peter Pearse.
>, i'd say just
> avoid the issue:
> - rename/move this driver to indicate it is specific to LPC2292
> - create a new driver based on the old one using the common SPI framework
Two additional questions:
- Which is the 'the common SPI framework'? Files?
- Just for correct understanding: We are talking about two issues
here? The first issue is that enc28j60.c has board specific code, for
e.g. setting GPIOs (as shown above)? And the second issue is that it
doesn't use common SPI framework? Correct?
> once it starts using the common SPI framework, i should be able to easily help
> with testing on Blackfin boards. we have a little addon card that lets us
> hook it up to a bunch of different boards.
Ok, I will have a look to it, but can't promise anything. At least it
sounds like a good plan :) Any help will be appreciated, though ;)
Best regards
Dirk
next prev parent reply other threads:[~2009-12-21 8:26 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-12-20 19:30 [U-Boot] Remove board specific code from ENC28J60 network driver? Dirk Behme
2009-12-20 19:54 ` Ben Warren
2009-12-20 20:05 ` Mike Frysinger
2009-12-21 8:26 ` Dirk Behme [this message]
2009-12-21 13:17 ` Mike Frysinger
2009-12-25 18:57 ` Dirk Behme
2009-12-26 18:40 ` Mike Frysinger
2009-12-27 7:59 ` Dirk Behme
2009-12-27 15:32 ` Ben Warren
2009-12-27 18:55 ` Dirk Behme
2009-12-28 18:33 ` Mike Frysinger
2009-12-28 21:29 ` Ben Warren
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4B2F311E.8020905@googlemail.com \
--to=dirk.behme@googlemail.com \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox