| The U-Boot Driver Model Project |
| =============================== |
| Hwmon device subsystem analysis |
| =============================== |
| |
| Tomas Hlavacek <tmshlvck@gmail.com> |
| 2012-03-02 |
| |
| I) Overview |
| ----------- |
| |
| U-Boot currently implements one API for HW monitoring devices. The |
| interface is defined in include/dtt.h and comprises of functions: |
| |
| void dtt_init(void); |
| int dtt_init_one(int); |
| int dtt_read(int sensor, int reg); |
| int dtt_write(int sensor, int reg, int val); |
| int dtt_get_temp(int sensor); |
| |
| The functions are implemented by a proper device driver in drivers/hwmon |
| directory and the driver to be compiled in is selected in a Makefile. |
| Drivers are mutually exclusive. |
| |
| Drivers depends on I2O code and naturally on board specific data. There are |
| few ad-hoc constants put in dtt.h file and driver headers and code. This |
| has to be consolidated into board specific data or driver headers if those |
| constants makes sense globally. |
| |
| |
| II) Approach |
| ------------ |
| |
| 1) New API |
| ---------- |
| In the UDM each hwmon driver would register itself by a function |
| |
| int hwmon_device_register(struct instance *i, |
| struct hwmon_device_ops *o); |
| |
| The structure being defined as follows: |
| |
| struct hwmon_device_ops { |
| int (*read)(struct instance *i, int sensor, int reg); |
| int (*write)(struct instance *i, int sensor, int reg, |
| int val); |
| int (*get_temp)(struct instance *i, int sensor); |
| }; |
| |
| |
| 2) Conversion thougths |
| ---------------------- |
| U-Boot hwmon drivers exports virtually the same functions (with exceptions) |
| and we are considering low number of drivers and code anyway. The interface |
| is already similar and unified by the interface defined in dtt.h. |
| Current initialization functions dtt_init() and dtt_init_one() will be |
| converted into probe() and hwmon_device_register(), so the funcionality will |
| be kept in more proper places. Besides implementing core registration and |
| initialization we need to do code cleanup, especially separate |
| driver-specific and HW specific constants. |
| |
| 3) Special consideration due to early initialization |
| ---------------------------------------------------- |
| The dtt_init() function call is used during early initialization in |
| board/gdsys/405ex/io64.c for starting up fans. The dtt code is perfectly |
| usable in the early stage because it uses only local variables and no heap |
| memory is required at this level. However the underlying code of I2C has to |
| keep the same properties with regard to possibility of running in early |
| initialization stage. |
| |
| III) Analysis of in-tree drivers |
| -------------------------------- |
| |
| 1) drivers/hwmon/lm81.c |
| ----------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 2) drivers/hwmon/ds1722.c |
| ------------------------- |
| The driver is not standard dtt, but interface is similar to dtt. |
| The interface has to be changed in order to comply to above mentioned |
| specification. |
| |
| |
| 3) drivers/hwmon/ds1775.c |
| ------------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 4) drivers/hwmon/lm73.c |
| ----------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 5) drivers/hwmon/lm63.c |
| ----------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 6) drivers/hwmon/adt7460.c |
| -------------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 7) drivers/hwmon/lm75.c |
| ----------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 8) drivers/hwmon/ds1621.c |
| ------------------------- |
| The driver is standard dtt. Simple conversion is possible. |
| |
| |
| 9) drivers/hwmon/adm1021.c |
| -------------------------- |
| The driver is standard dtt. Simple conversion is possible. |