[U-Boot] [PATCH v2 13/13] dm: Update documentation to include CONFIG_DM... options
Simon Glass
sjg at chromium.org
Fri Oct 24 03:05:30 CEST 2014
Hi Masahiro,
On 23 October 2014 14:17, Masahiro YAMADA <yamada.m at jp.panasonic.com> wrote:
> Hi Simon,
>
>
> 2014-10-24 4:16 GMT+09:00 Simon Glass <sjg at chromium.org>:
>> Add documentation for the various driver model options that are now
>> available.
>>
>> Signed-off-by: Simon Glass <sjg at chromium.org>
>> ---
>>
>> Changes in v2:
>> - Rebase to master
>>
>> README | 119 ++++++++++++++++++++++++++++++++++++++++++++
>> doc/driver-model/README.txt | 44 ++++++++++++----
>> 2 files changed, 153 insertions(+), 10 deletions(-)
>>
>> diff --git a/README b/README
>> index 19abe20..b679164 100644
>> --- a/README
>> +++ b/README
>> @@ -630,6 +630,120 @@ The following options need to be configured:
>> get_timer() must operate in milliseconds and this CONFIG
>> option must be set to 1000.
>>
>> +- Driver Model
>> + Driver model is a new framework for devices in U-Boot
>> + introduced in early 2014. U-Boot is being progressively
>> + moved over to this. It offers a consistent device structure,
>> + supports grouping devices into classes and has built-in
>> + handling of platform data and device tree.
>> +
>> + To enable transition to driver model in a relatively
>> + painful fashion, each subsystem can be independently
>> + switched between the legacy/ad-hoc approach and the new
>> + driver model using the options below. Also, many uclass
>> + interfaces include compatibility features which may be
>> + removed once the conversion of that subsystem is complete.
>> + As a result, the API provided by the subsystem may in fact
>> + not change with driver model.
>> +
>> + See doc/driver-model/README.txt for more information.
>> +
>> + CONFIG_DM
>> +
>> + Enable driver model. This brings in the core support,
>> + including scanning of platform data on start-up. If
>> + CONFIG_OF_CONTROL is enabled, the device tree will be
>> + scanned also when available.
>> +
>> + CONFIG_CMD_DM
>> +
>> + Enable driver model test commands. These allow you to print
>> + out the driver model tree and the uclasses.
>> +
>> + CONFIG_DM_DEMO
>> +
>> + Enable some demo devices and the 'demo' command. These are
>> + really only useful for playing around while trying to
>> + understand driver model in sandbox.
>> +
>> + CONFIG_SPL_DM
>> +
>> + Enable driver model in SPL. You will need to provide a
>> + suitable malloc() implementation. If you are not using the
>> + full malloc() enabled by CONFIG_SYS_SPL_MALLOC_START,
>> + consider using CONFIG_SYS_MALLOC_SIMPLE. In that case you
>> + must provide CONFIG_SYS_MALLOC_F_LEN to set the size.
>> + In most cases driver model will only allocate a few uclasses
>> + and devices in SPL, so 1KB should be enable. See
>> + CONFIG_SYS_MALLOC_F_LEN for more details on how to enable
>> + it.
>> +
>> + CONFIG_DM_SERIAL
>> +
>> + Enable driver model for serial. This replaces
>> + drivers/serial/serial.c with the serial uclass, which
>> + implements serial_putc() etc. The uclass interface is
>> + defined in include/serial.h.
>> +
>> + CONFIG_DM_GPIO
>> +
>> + Enable driver model for GPIO access. The standard GPIO
>> + interface (gpio_get_value(), etc.) is then implemented by
>> + the GPIO uclass. Drivers provide methods to query the
>> + particular GPIOs that they provide. The uclass interface
>> + is defined in include/asm-generic/gpio.h.
>> +
>> + CONFIG_DM_SPI
>> +
>> + Enable driver model for SPI. The SPI slave interface
>> + (spi_setup_slave(), spi_xfer(), etc.) is then implemented by
>> + the SPI uclass. Drivers provide methods to access the SPI
>> + buses that they control. The uclass interface is defined in
>> + include/spi.h. The existing spi_slave structure is attached
>> + as 'parent data' to every slave on each bus. Slaves
>> + typically use driver-private data instead of extending the
>> + spi_slave structure.
>> +
>> + CONFIG_DM_SPI_FLASH
>> +
>> + Enable driver model for SPI flash. This SPI flash interface
>> + (spi_flash_probe(), spi_flash_write(), etc.) is then
>> + implemented by the SPI flash uclass. There is one standard
>> + SPI flash driver which knows how to probe most chips
>> + supported by U-Boot. The uclass interface is defined in
>> + include/spi_flash.h, but is currently fully compatible
>> + with the old interface to avoid confusion and duplication
>> + during the transition parent. SPI and SPI flash must be
>> + enabled together (it is not possible to use driver model
>> + for one and not the other).
>> +
>> + CONFIG_DM_CROS_EC
>> +
>> + Enable driver model for the Chrome OS EC interface. This
>> + allows the cros_ec SPI driver to operate with CONFIG_DM_SPI
>> + but otherwise makes few changes. Since cros_ec also supports
>> + I2C and LPC (which don't support driver model yet), a full
>> + conversion is not yet possible.
>> +
>> +
>> + ** Code size options: The following options are enabled by
>> + default except in SPL. Enable them explicitly to get these
>> + features in SPL.
>> +
>> + CONFIG_DM_WARN
>> +
>> + Enable the dm_warn() function. This can use up quite a bit
>> + of space for its strings.
>> +
>> + CONFIG_DM_STDIO
>> +
>> + Enable registering a serial device with the stdio library.
>> +
>> + CONFIG_DM_DEVICE_REMOVE
>> +
>> + Enable removing of devices.
>> +
>
>
>
> Nice!
>
> Can we move them to Kconfig help (in this series or in a follow-up patch) ?
>
> I added some of them just for my instant necessity:
> http://patchwork.ozlabs.org/patch/402483/
> but my help messages might not be very nice.
> Please feel free to rewrite them as you like.
> Your documentation is more detailed!
>
> If you could send patches to prepare DM entries in Kconfig,
> that would be really helpful.
OK, let's merge everything and then one of us can move things over.
I'd like to move DM completely to Kconfig in the next week or so.
Regards,
Simon
More information about the U-Boot
mailing list