All of lore.kernel.org
 help / color / mirror / Atom feed
* [RFC linux v1 0/2] drivers: OCC hwmon driver restructuring
@ 2016-10-10 19:06 eajames.ibm
  2016-10-11  1:49 ` Andrew Jeffery
  0 siblings, 1 reply; 2+ messages in thread
From: eajames.ibm @ 2016-10-10 19:06 UTC (permalink / raw)
  To: openbmc

From: "Edward A. James" <eajames@us.ibm.com>

This patchset is provided to refactor the Power8 OCC hwmon driver. There are a
number of issues with the existing driver. Firstly, i2c access was embedded
throughout the driver. Secondly, there is no way to easily add different
versions of the OCC.

This patchset addresses the first issue by abstracting the bus transfer
protocol into a modular structure. In this way, any low level transfer method
may be easily implemented.

The second issue is addressed by separating the "version specific" code for the
OCC and the common hwmon code. This task is not yet complete, but the general
structure is in place. Ultimately, different OCC versions could be probed up
using the device tree.

Patch 1: "drivers: move OCC hwmon driver to occ directory"
* Move the Power8 OCC hwmon driver into it's own directory. Now we can
  have multiple files and avoid cluttering up the main hwmon directory.

Patch 2: "drivers: occ hwmon - isolate bus transfer protocol"
* modify drivers/hwmon Makefile and Kconfig
* create i2c layer
* move some common code out of the Power8 OCC specific file
* clean up Power8 OCC driver

Edward A. James (2):
  drivers: move OCC hwmon driver to occ directory
  drivers: occ hwmon - isolate bus transfer protocol

 drivers/hwmon/Kconfig          |   13 +-
 drivers/hwmon/Makefile         |    2 +-
 drivers/hwmon/occ/Kconfig      |   15 +
 drivers/hwmon/occ/Makefile     |    1 +
 drivers/hwmon/occ/occ.c        |  127 ++++
 drivers/hwmon/occ/occ.h        |   50 ++
 drivers/hwmon/occ/occ_i2c.c    |  191 ++++++
 drivers/hwmon/occ/power8_occ.c | 1048 +++++++++++++++++++++++++++++++++
 drivers/hwmon/occ/power8_occ.h |   24 +
 drivers/hwmon/power8_occ_i2c.c | 1254 ----------------------------------------
 10 files changed, 1458 insertions(+), 1267 deletions(-)
 create mode 100644 drivers/hwmon/occ/Kconfig
 create mode 100644 drivers/hwmon/occ/Makefile
 create mode 100644 drivers/hwmon/occ/occ.c
 create mode 100644 drivers/hwmon/occ/occ.h
 create mode 100644 drivers/hwmon/occ/occ_i2c.c
 create mode 100644 drivers/hwmon/occ/power8_occ.c
 create mode 100644 drivers/hwmon/occ/power8_occ.h
 delete mode 100644 drivers/hwmon/power8_occ_i2c.c

-- 
1.9.1

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [RFC linux v1 0/2] drivers: OCC hwmon driver restructuring
  2016-10-10 19:06 [RFC linux v1 0/2] drivers: OCC hwmon driver restructuring eajames.ibm
@ 2016-10-11  1:49 ` Andrew Jeffery
  0 siblings, 0 replies; 2+ messages in thread
From: Andrew Jeffery @ 2016-10-11  1:49 UTC (permalink / raw)
  To: eajames.ibm, openbmc

[-- Attachment #1: Type: text/plain, Size: 2817 bytes --]

Hi Eddie,

On Mon, 2016-10-10 at 14:06 -0500, eajames.ibm@gmail.com wrote:
> From: "Edward A. James" <eajames@us.ibm.com>
> 
> This patchset is provided to refactor the Power8 OCC hwmon driver. There are a
> number of issues with the existing driver. Firstly, i2c access was embedded
> throughout the driver. Secondly, there is no way to easily add different
> versions of the OCC.
> 
> This patchset addresses the first issue by abstracting the bus transfer
> protocol into a modular structure. In this way, any low level transfer method
> may be easily implemented.
> 
> The second issue is addressed by separating the "version specific" code for the
> OCC and the common hwmon code. This task is not yet complete, but the general
> structure is in place. Ultimately, different OCC versions could be probed up
> using the device tree.

Nice description.

As a side note, the associated patches didn't appear to thread under
the cover letter. `git send-email` should sort that out for you by
default, unless you added some extra switches (--no-thread)?

> 
> Patch 1: "drivers: move OCC hwmon driver to occ directory"
> * Move the Power8 OCC hwmon driver into it's own directory. Now we can
>   have multiple files and avoid cluttering up the main hwmon directory.
> 
> Patch 2: "drivers: occ hwmon - isolate bus transfer protocol"
> * modify drivers/hwmon Makefile and Kconfig
> * create i2c layer
> * move some common code out of the Power8 OCC specific file
> * clean up Power8 OCC driver

Four bullet points for one patch concerns me.

Andrew

> 
> Edward A. James (2):
>   drivers: move OCC hwmon driver to occ directory
>   drivers: occ hwmon - isolate bus transfer protocol
> 
>  drivers/hwmon/Kconfig          |   13 +-
>  drivers/hwmon/Makefile         |    2 +-
>  drivers/hwmon/occ/Kconfig      |   15 +
>  drivers/hwmon/occ/Makefile     |    1 +
>  drivers/hwmon/occ/occ.c        |  127 ++++
>  drivers/hwmon/occ/occ.h        |   50 ++
>  drivers/hwmon/occ/occ_i2c.c    |  191 ++++++
>  drivers/hwmon/occ/power8_occ.c | 1048 +++++++++++++++++++++++++++++++++
>  drivers/hwmon/occ/power8_occ.h |   24 +
>  drivers/hwmon/power8_occ_i2c.c | 1254 ----------------------------------------
>  10 files changed, 1458 insertions(+), 1267 deletions(-)
>  create mode 100644 drivers/hwmon/occ/Kconfig
>  create mode 100644 drivers/hwmon/occ/Makefile
>  create mode 100644 drivers/hwmon/occ/occ.c
>  create mode 100644 drivers/hwmon/occ/occ.h
>  create mode 100644 drivers/hwmon/occ/occ_i2c.c
>  create mode 100644 drivers/hwmon/occ/power8_occ.c
>  create mode 100644 drivers/hwmon/occ/power8_occ.h
>  delete mode 100644 drivers/hwmon/power8_occ_i2c.c
> 

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2016-10-11  1:49 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-10-10 19:06 [RFC linux v1 0/2] drivers: OCC hwmon driver restructuring eajames.ibm
2016-10-11  1:49 ` Andrew Jeffery

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.