Re: [PATCH 1/2] hwmon/sch5627: Add a sch5627_write_virtual_reg function

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On 05/04/2011 05:31 PM, Jean Delvare wrote:
Hi Hans,

On Thu, 21 Apr 2011 15:35:18 +0200, Hans de Goede wrote:
Signed-off-by: Hans de Goede<hdegoede@xxxxxxxxxx>

This patch adds the following warning:

   CC [M]  drivers/hwmon/sch5627.o
drivers/hwmon/sch5627.c:243:12: warning: âsch5627_write_virtual_regâ defined but not used

I get the point of splitting the changes into two separate patches, but
I'd rather introduce sch5627_write_virtual_reg() in the second patch,
where it is used, to avoid this warning.


Ok, I'll move the introduction of the sch5627_write_virtual_reg function to the
next patch, and adjust the commit msg.
Other than this, the code looks good, with just one suggestion below:

Will take over your suggestion as well. I'll send a new version when you
answer my question to your comments on the next patch.

Regards,

Hans


---
  drivers/hwmon/sch5627.c |   26 ++++++++++++++++++++++----
  1 files changed, 22 insertions(+), 4 deletions(-)

diff --git a/drivers/hwmon/sch5627.c b/drivers/hwmon/sch5627.c
index 9a51dcc..09a47bf 100644
--- a/drivers/hwmon/sch5627.c
+++ b/drivers/hwmon/sch5627.c
@@ -140,7 +140,7 @@ static inline void superio_exit(int base)
  	release_region(base, 2);
  }

-static int sch5627_read_virtual_reg(struct sch5627_data *data, u16 reg)
+static int sch5627_send_cmd(struct sch5627_data *data, u8 cmd, u16 reg, u8 v)
  {
  	u8 val;
  	int i;
@@ -163,10 +163,14 @@ static int sch5627_read_virtual_reg(struct sch5627_data *data, u16 reg)
  	outb(0x80, data->addr + 3);

  	/* Write Request Packet Header */
-	outb(0x02, data->addr + 4); /* Access Type: VREG read */
+	outb(cmd, data->addr + 4); /* VREG Access Type read:0x02 write:0x03 */

It might make sense to introduce defines for the read and write command
values? I think it would make the code more readable.

  	outb(0x01, data->addr + 5); /* # of Entries: 1 Byte (8-bit) */
  	outb(0x04, data->addr + 2); /* Mailbox AP to first data entry loc. */

+	/* Write Value field */
+	if (cmd == 0x03)
+		outb(v, data->addr + 4);
+
  	/* Write Address field */
  	outb(reg&  0xff, data->addr + 6);
  	outb(reg>>  8, data->addr + 7);
@@ -224,8 +228,22 @@ static int sch5627_read_virtual_reg(struct sch5627_data *data, u16 reg)
  	 * But if we do that things don't work, so let's not.
  	 */

-	/* Read Data from Mailbox */
-	return inb(data->addr + 4);
+	/* Read Value field */
+	if (cmd == 0x02)
+		return inb(data->addr + 4);
+
+	return 0;
+}
+
+static int sch5627_read_virtual_reg(struct sch5627_data *data, u16 reg)
+{
+	return sch5627_send_cmd(data, 0x02, reg, 0);
+}
+
+static int sch5627_write_virtual_reg(struct sch5627_data *data,
+				     u16 reg, u8 val)
+{
+	return sch5627_send_cmd(data, 0x03, reg, val);
  }

  static int sch5627_read_virtual_reg16(struct sch5627_data *data, u16 reg)



_______________________________________________
lm-sensors mailing list
lm-sensors@xxxxxxxxxxxxxx
http://lists.lm-sensors.org/mailman/listinfo/lm-sensors



[Index of Archives]     [Linux Kernel]     [Linux Hardware Monitoring]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux