[PATCH v3 00/23] Create common framework for AT91 device initialisation
Ryan Mallon
ryan at bluewatersys.com
Fri Apr 29 16:14:58 EDT 2011
On 30/04/11 06:04, H Hartley Sweeten wrote:
> On Thursday, April 28, 2011 7:59 PM, Ryan Mallon wrote:
>>
>> Each AT91 variant (AT91RM9200, AT91SAM9260, etc) currently has its own
>> devices file, which includes the MMIO address, interrupt
>> configuration, GPIO setup, etc for each device. This results in a large
>> amount of duplicated code.
>>
>> This patch set introduces a framework for adding shared devices for the
>> AT91 platform and replaces the multiple device setup implementations for
>> each device with single implementations in the new framework. This has
>> a net reduction of nearly 5000 lines of code.
>>
>> Each of the arch/arm/mach-at91/*_devices.c files becomes a collection of
>> structures (with some initialisation callbacks where necessary) with a
>> table of devices which are present on the particular AT91 variant. All
>> structures/functions are marked as __init/__initdata so there is little
>> additional memory overhead. This also means that the #ifdefs around each
>> device can be removed from the *_devices.c files (but remain in the new
>> common devices.c file) without overhead.
>>
>> This patch series does not introduce any functional changes to how the
>> board files add devices, it only replaces the duplicate device
>> initialisation code with common versions. The patch series attempts to
>> have minimum change by rewriting as little as possible of the actual
>> device initialisation functions.
>>
>> This is also a step towards allowing more than one AT91 variant to be
>> built into a single kernel by removing duplicate function names across
>> the *_devices.c files.
>>
>> I have build tested the patch series for all of the AT91 variants
>> and devices, and have boot tested it on the AT91SAM9G20 (Snapper 9G20
>> board) and tested basic device functionality.
>
> Ryan,
>
> This patch series does not apply to linux-next.
>
> It appears Jean-Christophe PLAGNIOL-VILLARD has recently committed a number
> of patches to that branch.
>
> at91: move clock subsystem init to soc generic init
> at91: move register clocks to soc generic init
> at91: move st timer to drivers/clocksource
> at91: move pit timer to drivers/clocksource
> at91: switch st timer to early platform devices
> at91: switch pit timer to early platform devices
> at91: move gpio to drivers/gpio
> at91: switch gpio to early platfrom device
> at91: switch to CLKDEV_LOOKUP
> at91: use structure to store the current soc
> at91: merge board usb-a9260 and usb-a9263 together
> at91: factorize at91 interrupts init to soc
> at91: introduce commom AT91_BASE_SYS
> at91rm9200: introduce at91rm9200_set_type to specficy cpu package
> at91: 9260 and 9g20 add support of join SRAM Memory Mapping
> at91/board-eco920: remove at91_beeper ressource as no driver at91_beeper exist
> atmel_serial: keep the platform_device unchanged
> at91: remove MTD_NAND_ATMEL_BUSWIDTH_16 option
> at91: Add ARCH_ID and basic cpu macros definition for 5series chips family.
>
> There are also these three ahead of Linus' linux-2.6 tree:
>
> arm: at91: fix compiler warning for eb01 board build
> ARM: at91: AT91CAP9 has a macb device
> treewide: remove extra semicolons
Ok, I have more changes to make anyway so I will rebase against these
three. I do not want to rebase on top of the Jean-Christophe's patches
because I do not think that they are ready for mainline inclusion. See
the discussion in the other thread.
~Ryan
More information about the linux-arm-kernel
mailing list