Re: [PATCH 1/2] hwmon: (emc2305) fix unable to probe emc2301/2/3/4

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

 



On 12/5/22 09:36, Xingjiang Qiao wrote:
The definitions of 'EMC2305_REG_PRODUCT_ID' and 'EMC2305_REG_DEVICE' are
both '0xfd', they actually return the same value, but the values returned
by emc2301/2/3/4/5 are different, so probe emc2301/2/3/4 will fail, This
patch fixes that.


This solves the wrong problem. The check for REG_DEVICE should simply
be removed instead (EMC2305_REG_PRODUCT_ID and EMC2305_REG_DEVICE are
both 0xfd). On top of that, moving the functionality of emc2305_identify()
does not improve code quality (quite the contrary) and is thus not acceptable.

The second parameter of 'emc2305_probe' is actually useless, it is more
appropriate to use 'probe_new' instead of 'probe' here.


This would be a second patch. Besides, this change is already queued in
hwmon-next for v6.2.

Guenter

Signed-off-by: Xingjiang Qiao <nanpuyue@xxxxxxxxx>
---
  drivers/hwmon/emc2305.c | 58 ++++++++++++++---------------------------
  1 file changed, 19 insertions(+), 39 deletions(-)

diff --git a/drivers/hwmon/emc2305.c b/drivers/hwmon/emc2305.c
index aa1f25add0b6..4df84065cbfb 100644
--- a/drivers/hwmon/emc2305.c
+++ b/drivers/hwmon/emc2305.c
@@ -21,9 +21,7 @@ emc2305_normal_i2c[] = { 0x27, 0x2c, 0x2d, 0x2e, 0x2f, 0x4c, 0x4d, I2C_CLIENT_EN
  #define EMC2305_FAN_MAX			0xff
  #define EMC2305_FAN_MIN			0x00
  #define EMC2305_FAN_MAX_STATE		10
-#define EMC2305_DEVICE			0x34
  #define EMC2305_VENDOR			0x5d
-#define EMC2305_REG_PRODUCT_ID		0xfd
  #define EMC2305_TACH_REGS_UNUSE_BITS	3
  #define EMC2305_TACH_CNT_MULTIPLIER	0x02
  #define EMC2305_TACH_RANGE_MIN		480
@@ -488,43 +486,14 @@ static const struct hwmon_chip_info emc2305_chip_info = {
  	.info = emc2305_info,
  };
-static int emc2305_identify(struct device *dev)
-{
-	struct i2c_client *client = to_i2c_client(dev);
-	struct emc2305_data *data = i2c_get_clientdata(client);
-	int ret;
-
-	ret = i2c_smbus_read_byte_data(client, EMC2305_REG_PRODUCT_ID);
-	if (ret < 0)
-		return ret;
-
-	switch (ret) {
-	case EMC2305:
-		data->pwm_num = 5;
-		break;
-	case EMC2303:
-		data->pwm_num = 3;
-		break;
-	case EMC2302:
-		data->pwm_num = 2;
-		break;
-	case EMC2301:
-		data->pwm_num = 1;
-		break;
-	default:
-		return -ENODEV;
-	}
-
-	return 0;
-}
-
-static int emc2305_probe(struct i2c_client *client, const struct i2c_device_id *id)
+static int emc2305_probe(struct i2c_client *client)
  {
  	struct i2c_adapter *adapter = client->adapter;
  	struct device *dev = &client->dev;
  	struct emc2305_data *data;
  	struct emc2305_platform_data *pdata;
  	int vendor, device;
+	int pwm_num;
  	int ret;
  	int i;
@@ -536,20 +505,31 @@ static int emc2305_probe(struct i2c_client *client, const struct i2c_device_id *
  		return -ENODEV;
device = i2c_smbus_read_byte_data(client, EMC2305_REG_DEVICE);
-	if (device != EMC2305_DEVICE)
+	switch (device) {
+	case EMC2305:
+		pwm_num = 5;
+		break;
+	case EMC2303:
+		pwm_num = 3;
+		break;
+	case EMC2302:
+		pwm_num = 2;
+		break;
+	case EMC2301:
+		pwm_num = 1;
+		break;
+	default:
  		return -ENODEV;
+	}
data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
  	if (!data)
  		return -ENOMEM;
i2c_set_clientdata(client, data);
+	data->pwm_num = pwm_num;
  	data->client = client;
- ret = emc2305_identify(dev);
-	if (ret)
-		return ret;
-
  	pdata = dev_get_platdata(&client->dev);
  	if (pdata) {
  		if (!pdata->max_state || pdata->max_state > EMC2305_FAN_MAX_STATE)
@@ -604,10 +584,10 @@ static void emc2305_remove(struct i2c_client *client)
static struct i2c_driver emc2305_driver = {
  	.class  = I2C_CLASS_HWMON,
+	.probe_new = emc2305_probe,
  	.driver = {
  		.name = "emc2305",
  	},
-	.probe    = emc2305_probe,
  	.remove	  = emc2305_remove,
  	.id_table = emc2305_ids,
  	.address_list = emc2305_normal_i2c,




[Index of Archives]     [LM Sensors]     [Linux Sound]     [ALSA Users]     [ALSA Devel]     [Linux Audio Users]     [Linux Media]     [Kernel]     [Gimp]     [Yosemite News]     [Linux Media]

  Powered by Linux