diff options
author | Jean Delvare <khali@linux-fr.org> | 2008-10-17 11:51:13 -0400 |
---|---|---|
committer | Jean Delvare <khali@mahadeva.delvare> | 2008-10-17 11:51:13 -0400 |
commit | 69fc1feba2d5856ff74dedb6ae9d8c490210825c (patch) | |
tree | 11fd5e34315dd86ca23fbf2eb18af24f4794032f /drivers/hwmon | |
parent | dbee356262bb1c84cfa585530e33e7003534052a (diff) |
hwmon: (lm85) Rework the device detection
Rework the device detection to make it clearer and faster in the
general case (when a known device is found.)
Signed-off-by: Jean Delvare <khali@linux-fr.org>
Acked-by: Herbert Poetzl <herbert@13thfloor.at>
Diffstat (limited to 'drivers/hwmon')
-rw-r--r-- | drivers/hwmon/lm85.c | 123 |
1 files changed, 50 insertions, 73 deletions
diff --git a/drivers/hwmon/lm85.c b/drivers/hwmon/lm85.c index 12d446f54f97..3594a02f281b 100644 --- a/drivers/hwmon/lm85.c +++ b/drivers/hwmon/lm85.c | |||
@@ -1106,7 +1106,6 @@ static void lm85_init_client(struct i2c_client *client) | |||
1106 | static int lm85_detect(struct i2c_adapter *adapter, int address, | 1106 | static int lm85_detect(struct i2c_adapter *adapter, int address, |
1107 | int kind) | 1107 | int kind) |
1108 | { | 1108 | { |
1109 | int company, verstep; | ||
1110 | struct i2c_client *client; | 1109 | struct i2c_client *client; |
1111 | struct lm85_data *data; | 1110 | struct lm85_data *data; |
1112 | int err = 0; | 1111 | int err = 0; |
@@ -1117,10 +1116,6 @@ static int lm85_detect(struct i2c_adapter *adapter, int address, | |||
1117 | goto ERROR0; | 1116 | goto ERROR0; |
1118 | } | 1117 | } |
1119 | 1118 | ||
1120 | /* OK. For now, we presume we have a valid client. We now create the | ||
1121 | client structure, even though we cannot fill it completely yet. | ||
1122 | But it allows us to access lm85_{read,write}_value. */ | ||
1123 | |||
1124 | if (!(data = kzalloc(sizeof(struct lm85_data), GFP_KERNEL))) { | 1119 | if (!(data = kzalloc(sizeof(struct lm85_data), GFP_KERNEL))) { |
1125 | err = -ENOMEM; | 1120 | err = -ENOMEM; |
1126 | goto ERROR0; | 1121 | goto ERROR0; |
@@ -1132,75 +1127,57 @@ static int lm85_detect(struct i2c_adapter *adapter, int address, | |||
1132 | client->adapter = adapter; | 1127 | client->adapter = adapter; |
1133 | client->driver = &lm85_driver; | 1128 | client->driver = &lm85_driver; |
1134 | 1129 | ||
1135 | /* Now, we do the remaining detection. */ | 1130 | /* If auto-detecting, determine the chip type */ |
1136 | 1131 | if (kind < 0) { | |
1137 | company = lm85_read_value(client, LM85_REG_COMPANY); | 1132 | int company = lm85_read_value(client, LM85_REG_COMPANY); |
1138 | verstep = lm85_read_value(client, LM85_REG_VERSTEP); | 1133 | int verstep = lm85_read_value(client, LM85_REG_VERSTEP); |
1139 | 1134 | ||
1140 | dev_dbg(&adapter->dev, "Detecting device at %d,0x%02x with" | 1135 | dev_dbg(&adapter->dev, "Detecting device at 0x%02x with " |
1141 | " COMPANY: 0x%02x and VERSTEP: 0x%02x\n", | 1136 | "COMPANY: 0x%02x and VERSTEP: 0x%02x\n", |
1142 | i2c_adapter_id(client->adapter), client->addr, | 1137 | address, company, verstep); |
1143 | company, verstep); | 1138 | |
1144 | 1139 | /* All supported chips have the version in common */ | |
1145 | /* If auto-detecting, Determine the chip type. */ | 1140 | if ((verstep & LM85_VERSTEP_VMASK) != LM85_VERSTEP_GENERIC) { |
1146 | if (kind <= 0) { | 1141 | dev_dbg(&adapter->dev, "Autodetection failed: " |
1147 | dev_dbg(&adapter->dev, "Autodetecting device at %d,0x%02x ...\n", | 1142 | "unsupported version\n"); |
1148 | i2c_adapter_id(adapter), address); | 1143 | goto ERROR1; |
1149 | if (company == LM85_COMPANY_NATIONAL | 1144 | } |
1150 | && verstep == LM85_VERSTEP_LM85C) { | 1145 | kind = any_chip; |
1151 | kind = lm85c; | 1146 | |
1152 | } else if (company == LM85_COMPANY_NATIONAL | 1147 | /* Now, refine the detection */ |
1153 | && verstep == LM85_VERSTEP_LM85B) { | 1148 | if (company == LM85_COMPANY_NATIONAL) { |
1154 | kind = lm85b; | 1149 | switch (verstep) { |
1155 | } else if (company == LM85_COMPANY_NATIONAL | 1150 | case LM85_VERSTEP_LM85C: |
1156 | && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) { | 1151 | kind = lm85c; |
1157 | dev_err(&adapter->dev, "Unrecognized version/stepping 0x%02x" | 1152 | break; |
1158 | " Defaulting to LM85.\n", verstep); | 1153 | case LM85_VERSTEP_LM85B: |
1159 | kind = any_chip; | 1154 | kind = lm85b; |
1160 | } else if (company == LM85_COMPANY_ANALOG_DEV | 1155 | break; |
1161 | && verstep == LM85_VERSTEP_ADM1027) { | 1156 | } |
1162 | kind = adm1027; | 1157 | } else if (company == LM85_COMPANY_ANALOG_DEV) { |
1163 | } else if (company == LM85_COMPANY_ANALOG_DEV | 1158 | switch (verstep) { |
1164 | && (verstep == LM85_VERSTEP_ADT7463 | 1159 | case LM85_VERSTEP_ADM1027: |
1165 | || verstep == LM85_VERSTEP_ADT7463C)) { | 1160 | kind = adm1027; |
1166 | kind = adt7463; | 1161 | break; |
1167 | } else if (company == LM85_COMPANY_ANALOG_DEV | 1162 | case LM85_VERSTEP_ADT7463: |
1168 | && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) { | 1163 | case LM85_VERSTEP_ADT7463C: |
1169 | dev_err(&adapter->dev, "Unrecognized version/stepping 0x%02x" | 1164 | kind = adt7463; |
1170 | " Defaulting to Generic LM85.\n", verstep); | 1165 | break; |
1171 | kind = any_chip; | ||
1172 | } else if (company == LM85_COMPANY_SMSC | ||
1173 | && (verstep == LM85_VERSTEP_EMC6D100_A0 | ||
1174 | || verstep == LM85_VERSTEP_EMC6D100_A1)) { | ||
1175 | /* Unfortunately, we can't tell a '100 from a '101 | ||
1176 | * from the registers. Since a '101 is a '100 | ||
1177 | * in a package with fewer pins and therefore no | ||
1178 | * 3.3V, 1.5V or 1.8V inputs, perhaps if those | ||
1179 | * inputs read 0, then it's a '101. | ||
1180 | */ | ||
1181 | kind = emc6d100; | ||
1182 | } else if (company == LM85_COMPANY_SMSC | ||
1183 | && verstep == LM85_VERSTEP_EMC6D102) { | ||
1184 | kind = emc6d102; | ||
1185 | } else if (company == LM85_COMPANY_SMSC | ||
1186 | && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) { | ||
1187 | dev_err(&adapter->dev, "lm85: Detected SMSC chip\n"); | ||
1188 | dev_err(&adapter->dev, "lm85: Unrecognized version/stepping 0x%02x" | ||
1189 | " Defaulting to Generic LM85.\n", verstep); | ||
1190 | kind = any_chip; | ||
1191 | } else if (kind == any_chip | ||
1192 | && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) { | ||
1193 | dev_err(&adapter->dev, "Generic LM85 Version 6 detected\n"); | ||
1194 | /* Leave kind as "any_chip" */ | ||
1195 | } else { | ||
1196 | dev_dbg(&adapter->dev, "Autodetection failed\n"); | ||
1197 | /* Not an LM85... */ | ||
1198 | if (kind == any_chip) { /* User used force=x,y */ | ||
1199 | dev_err(&adapter->dev, "Generic LM85 Version 6 not" | ||
1200 | " found at %d,0x%02x. Try force_lm85c.\n", | ||
1201 | i2c_adapter_id(adapter), address); | ||
1202 | } | 1166 | } |
1203 | err = 0; | 1167 | } else if (company == LM85_COMPANY_SMSC) { |
1168 | switch (verstep) { | ||
1169 | case LM85_VERSTEP_EMC6D100_A0: | ||
1170 | case LM85_VERSTEP_EMC6D100_A1: | ||
1171 | /* Note: we can't tell a '100 from a '101 */ | ||
1172 | kind = emc6d100; | ||
1173 | break; | ||
1174 | case LM85_VERSTEP_EMC6D102: | ||
1175 | kind = emc6d102; | ||
1176 | break; | ||
1177 | } | ||
1178 | } else { | ||
1179 | dev_dbg(&adapter->dev, "Autodetection failed: " | ||
1180 | "unknown vendor\n"); | ||
1204 | goto ERROR1; | 1181 | goto ERROR1; |
1205 | } | 1182 | } |
1206 | } | 1183 | } |