diff options
Diffstat (limited to 'drivers/i2c')
-rw-r--r-- | drivers/i2c/busses/i2c-nforce2.c | 152 |
1 files changed, 76 insertions, 76 deletions
diff --git a/drivers/i2c/busses/i2c-nforce2.c b/drivers/i2c/busses/i2c-nforce2.c index adac8542771d..ac88f4000cc2 100644 --- a/drivers/i2c/busses/i2c-nforce2.c +++ b/drivers/i2c/busses/i2c-nforce2.c | |||
@@ -60,7 +60,7 @@ | |||
60 | #include <linux/io.h> | 60 | #include <linux/io.h> |
61 | 61 | ||
62 | MODULE_LICENSE("GPL"); | 62 | MODULE_LICENSE("GPL"); |
63 | MODULE_AUTHOR ("Hans-Frieder Vogt <hfvogt@gmx.net>"); | 63 | MODULE_AUTHOR("Hans-Frieder Vogt <hfvogt@gmx.net>"); |
64 | MODULE_DESCRIPTION("nForce2/3/4/5xx SMBus driver"); | 64 | MODULE_DESCRIPTION("nForce2/3/4/5xx SMBus driver"); |
65 | 65 | ||
66 | 66 | ||
@@ -188,9 +188,9 @@ static int nforce2_check_status(struct i2c_adapter *adap) | |||
188 | } | 188 | } |
189 | 189 | ||
190 | /* Return negative errno on error */ | 190 | /* Return negative errno on error */ |
191 | static s32 nforce2_access(struct i2c_adapter * adap, u16 addr, | 191 | static s32 nforce2_access(struct i2c_adapter *adap, u16 addr, |
192 | unsigned short flags, char read_write, | 192 | unsigned short flags, char read_write, |
193 | u8 command, int size, union i2c_smbus_data * data) | 193 | u8 command, int size, union i2c_smbus_data *data) |
194 | { | 194 | { |
195 | struct nforce2_smbus *smbus = adap->algo_data; | 195 | struct nforce2_smbus *smbus = adap->algo_data; |
196 | unsigned char protocol, pec; | 196 | unsigned char protocol, pec; |
@@ -202,56 +202,54 @@ static s32 nforce2_access(struct i2c_adapter * adap, u16 addr, | |||
202 | pec = (flags & I2C_CLIENT_PEC) ? NVIDIA_SMB_PRTCL_PEC : 0; | 202 | pec = (flags & I2C_CLIENT_PEC) ? NVIDIA_SMB_PRTCL_PEC : 0; |
203 | 203 | ||
204 | switch (size) { | 204 | switch (size) { |
205 | case I2C_SMBUS_QUICK: | ||
206 | protocol |= NVIDIA_SMB_PRTCL_QUICK; | ||
207 | read_write = I2C_SMBUS_WRITE; | ||
208 | break; | ||
205 | 209 | ||
206 | case I2C_SMBUS_QUICK: | 210 | case I2C_SMBUS_BYTE: |
207 | protocol |= NVIDIA_SMB_PRTCL_QUICK; | 211 | if (read_write == I2C_SMBUS_WRITE) |
208 | read_write = I2C_SMBUS_WRITE; | ||
209 | break; | ||
210 | |||
211 | case I2C_SMBUS_BYTE: | ||
212 | if (read_write == I2C_SMBUS_WRITE) | ||
213 | outb_p(command, NVIDIA_SMB_CMD); | ||
214 | protocol |= NVIDIA_SMB_PRTCL_BYTE; | ||
215 | break; | ||
216 | |||
217 | case I2C_SMBUS_BYTE_DATA: | ||
218 | outb_p(command, NVIDIA_SMB_CMD); | ||
219 | if (read_write == I2C_SMBUS_WRITE) | ||
220 | outb_p(data->byte, NVIDIA_SMB_DATA); | ||
221 | protocol |= NVIDIA_SMB_PRTCL_BYTE_DATA; | ||
222 | break; | ||
223 | |||
224 | case I2C_SMBUS_WORD_DATA: | ||
225 | outb_p(command, NVIDIA_SMB_CMD); | 212 | outb_p(command, NVIDIA_SMB_CMD); |
226 | if (read_write == I2C_SMBUS_WRITE) { | 213 | protocol |= NVIDIA_SMB_PRTCL_BYTE; |
227 | outb_p(data->word, NVIDIA_SMB_DATA); | 214 | break; |
228 | outb_p(data->word >> 8, NVIDIA_SMB_DATA+1); | 215 | |
229 | } | 216 | case I2C_SMBUS_BYTE_DATA: |
230 | protocol |= NVIDIA_SMB_PRTCL_WORD_DATA | pec; | 217 | outb_p(command, NVIDIA_SMB_CMD); |
231 | break; | 218 | if (read_write == I2C_SMBUS_WRITE) |
232 | 219 | outb_p(data->byte, NVIDIA_SMB_DATA); | |
233 | case I2C_SMBUS_BLOCK_DATA: | 220 | protocol |= NVIDIA_SMB_PRTCL_BYTE_DATA; |
234 | outb_p(command, NVIDIA_SMB_CMD); | 221 | break; |
235 | if (read_write == I2C_SMBUS_WRITE) { | 222 | |
236 | len = data->block[0]; | 223 | case I2C_SMBUS_WORD_DATA: |
237 | if ((len == 0) || (len > I2C_SMBUS_BLOCK_MAX)) { | 224 | outb_p(command, NVIDIA_SMB_CMD); |
238 | dev_err(&adap->dev, | 225 | if (read_write == I2C_SMBUS_WRITE) { |
239 | "Transaction failed " | 226 | outb_p(data->word, NVIDIA_SMB_DATA); |
240 | "(requested block size: %d)\n", | 227 | outb_p(data->word >> 8, NVIDIA_SMB_DATA + 1); |
241 | len); | 228 | } |
242 | return -EINVAL; | 229 | protocol |= NVIDIA_SMB_PRTCL_WORD_DATA | pec; |
243 | } | 230 | break; |
244 | outb_p(len, NVIDIA_SMB_BCNT); | 231 | |
245 | for (i = 0; i < I2C_SMBUS_BLOCK_MAX; i++) | 232 | case I2C_SMBUS_BLOCK_DATA: |
246 | outb_p(data->block[i + 1], | 233 | outb_p(command, NVIDIA_SMB_CMD); |
247 | NVIDIA_SMB_DATA+i); | 234 | if (read_write == I2C_SMBUS_WRITE) { |
235 | len = data->block[0]; | ||
236 | if ((len == 0) || (len > I2C_SMBUS_BLOCK_MAX)) { | ||
237 | dev_err(&adap->dev, | ||
238 | "Transaction failed (requested block size: %d)\n", | ||
239 | len); | ||
240 | return -EINVAL; | ||
248 | } | 241 | } |
249 | protocol |= NVIDIA_SMB_PRTCL_BLOCK_DATA | pec; | 242 | outb_p(len, NVIDIA_SMB_BCNT); |
250 | break; | 243 | for (i = 0; i < I2C_SMBUS_BLOCK_MAX; i++) |
244 | outb_p(data->block[i + 1], | ||
245 | NVIDIA_SMB_DATA + i); | ||
246 | } | ||
247 | protocol |= NVIDIA_SMB_PRTCL_BLOCK_DATA | pec; | ||
248 | break; | ||
251 | 249 | ||
252 | default: | 250 | default: |
253 | dev_err(&adap->dev, "Unsupported transaction %d\n", size); | 251 | dev_err(&adap->dev, "Unsupported transaction %d\n", size); |
254 | return -EOPNOTSUPP; | 252 | return -EOPNOTSUPP; |
255 | } | 253 | } |
256 | 254 | ||
257 | outb_p((addr & 0x7f) << 1, NVIDIA_SMB_ADDR); | 255 | outb_p((addr & 0x7f) << 1, NVIDIA_SMB_ADDR); |
@@ -265,28 +263,28 @@ static s32 nforce2_access(struct i2c_adapter * adap, u16 addr, | |||
265 | return 0; | 263 | return 0; |
266 | 264 | ||
267 | switch (size) { | 265 | switch (size) { |
268 | 266 | case I2C_SMBUS_BYTE: | |
269 | case I2C_SMBUS_BYTE: | 267 | case I2C_SMBUS_BYTE_DATA: |
270 | case I2C_SMBUS_BYTE_DATA: | 268 | data->byte = inb_p(NVIDIA_SMB_DATA); |
271 | data->byte = inb_p(NVIDIA_SMB_DATA); | 269 | break; |
272 | break; | 270 | |
273 | 271 | case I2C_SMBUS_WORD_DATA: | |
274 | case I2C_SMBUS_WORD_DATA: | 272 | data->word = inb_p(NVIDIA_SMB_DATA) | |
275 | data->word = inb_p(NVIDIA_SMB_DATA) | (inb_p(NVIDIA_SMB_DATA+1) << 8); | 273 | (inb_p(NVIDIA_SMB_DATA + 1) << 8); |
276 | break; | 274 | break; |
277 | 275 | ||
278 | case I2C_SMBUS_BLOCK_DATA: | 276 | case I2C_SMBUS_BLOCK_DATA: |
279 | len = inb_p(NVIDIA_SMB_BCNT); | 277 | len = inb_p(NVIDIA_SMB_BCNT); |
280 | if ((len <= 0) || (len > I2C_SMBUS_BLOCK_MAX)) { | 278 | if ((len <= 0) || (len > I2C_SMBUS_BLOCK_MAX)) { |
281 | dev_err(&adap->dev, "Transaction failed " | 279 | dev_err(&adap->dev, |
282 | "(received block size: 0x%02x)\n", | 280 | "Transaction failed (received block size: 0x%02x)\n", |
283 | len); | 281 | len); |
284 | return -EPROTO; | 282 | return -EPROTO; |
285 | } | 283 | } |
286 | for (i = 0; i < len; i++) | 284 | for (i = 0; i < len; i++) |
287 | data->block[i+1] = inb_p(NVIDIA_SMB_DATA + i); | 285 | data->block[i + 1] = inb_p(NVIDIA_SMB_DATA + i); |
288 | data->block[0] = len; | 286 | data->block[0] = len; |
289 | break; | 287 | break; |
290 | } | 288 | } |
291 | 289 | ||
292 | return 0; | 290 | return 0; |
@@ -299,7 +297,7 @@ static u32 nforce2_func(struct i2c_adapter *adapter) | |||
299 | return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE | | 297 | return I2C_FUNC_SMBUS_QUICK | I2C_FUNC_SMBUS_BYTE | |
300 | I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA | | 298 | I2C_FUNC_SMBUS_BYTE_DATA | I2C_FUNC_SMBUS_WORD_DATA | |
301 | I2C_FUNC_SMBUS_PEC | | 299 | I2C_FUNC_SMBUS_PEC | |
302 | (((struct nforce2_smbus*)adapter->algo_data)->blockops ? | 300 | (((struct nforce2_smbus *)adapter->algo_data)->blockops ? |
303 | I2C_FUNC_SMBUS_BLOCK_DATA : 0); | 301 | I2C_FUNC_SMBUS_BLOCK_DATA : 0); |
304 | } | 302 | } |
305 | 303 | ||
@@ -327,7 +325,7 @@ static DEFINE_PCI_DEVICE_TABLE(nforce2_ids) = { | |||
327 | { 0 } | 325 | { 0 } |
328 | }; | 326 | }; |
329 | 327 | ||
330 | MODULE_DEVICE_TABLE (pci, nforce2_ids); | 328 | MODULE_DEVICE_TABLE(pci, nforce2_ids); |
331 | 329 | ||
332 | 330 | ||
333 | static int nforce2_probe_smb(struct pci_dev *dev, int bar, int alt_reg, | 331 | static int nforce2_probe_smb(struct pci_dev *dev, int bar, int alt_reg, |
@@ -377,7 +375,8 @@ static int nforce2_probe_smb(struct pci_dev *dev, int bar, int alt_reg, | |||
377 | release_region(smbus->base, smbus->size); | 375 | release_region(smbus->base, smbus->size); |
378 | return error; | 376 | return error; |
379 | } | 377 | } |
380 | dev_info(&smbus->adapter.dev, "nForce2 SMBus adapter at %#x\n", smbus->base); | 378 | dev_info(&smbus->adapter.dev, "nForce2 SMBus adapter at %#x\n", |
379 | smbus->base); | ||
381 | return 0; | 380 | return 0; |
382 | } | 381 | } |
383 | 382 | ||
@@ -388,11 +387,12 @@ static int nforce2_probe(struct pci_dev *dev, const struct pci_device_id *id) | |||
388 | int res1, res2; | 387 | int res1, res2; |
389 | 388 | ||
390 | /* we support 2 SMBus adapters */ | 389 | /* we support 2 SMBus adapters */ |
391 | if (!(smbuses = kzalloc(2*sizeof(struct nforce2_smbus), GFP_KERNEL))) | 390 | smbuses = kzalloc(2 * sizeof(struct nforce2_smbus), GFP_KERNEL); |
391 | if (!smbuses) | ||
392 | return -ENOMEM; | 392 | return -ENOMEM; |
393 | pci_set_drvdata(dev, smbuses); | 393 | pci_set_drvdata(dev, smbuses); |
394 | 394 | ||
395 | switch(dev->device) { | 395 | switch (dev->device) { |
396 | case PCI_DEVICE_ID_NVIDIA_NFORCE2_SMBUS: | 396 | case PCI_DEVICE_ID_NVIDIA_NFORCE2_SMBUS: |
397 | case PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SMBUS: | 397 | case PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SMBUS: |
398 | case PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SMBUS: | 398 | case PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SMBUS: |