dm: Introduce device sequence numbering
authorSimon Glass <sjg@chromium.org>
Wed, 23 Jul 2014 12:55:12 +0000 (06:55 -0600)
committerSimon Glass <sjg@chromium.org>
Wed, 23 Jul 2014 13:07:25 +0000 (14:07 +0100)
commit5a66a8ff86d923367ca9a1f6168e976fbde27391
tree429ae5e3e439c59972c845673ee3d48ef23d416e
parent4e8bc211703d3c93689367745e8c07dc22c68dfc
dm: Introduce device sequence numbering

In U-Boot it is pretty common to number devices from 0 and access them
on the command line using this numbering. While it may come to pass that
we will move away from this numbering, the possibility seems remote at
present.

Given that devices within a uclass will have an implied numbering, it
makes sense to build this into driver model as a core feature. The cost
is fairly small in terms of code and data space.

With each uclass having numbered devices we can ask for SPI port 0 or
serial port 1 and receive a single device.

Devices typically request a sequence number using aliases in the device
tree. These are resolved when the device is probed, to deal with conflicts.
Sequence numbers need not be sequential and holes are permitted.

At present there is no support for sequence numbers using static platform
data. It could easily be added to 'struct driver_info' if needed, but it
seems better to add features as we find a use for them, and the use of -1
to mean 'no sequence' makes the default value somewhat painful.

Signed-off-by: Simon Glass <sjg@chromium.org>
doc/driver-model/README.txt
drivers/core/device.c
drivers/core/uclass.c
include/dm/device.h
include/dm/uclass-internal.h
include/dm/uclass.h
test/dm/test-fdt.c
test/dm/test.dts