-
Notifications
You must be signed in to change notification settings - Fork 174
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add support for SFF_8472/SFP+ standard
- Loading branch information
Showing
3 changed files
with
398 additions
and
172 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,116 +1,71 @@ | ||
Update SFF8436 EEPROM driver | ||
Support newer kernel and remove eeprom_class dependency in sff_8436_eeprom | ||
|
||
From: Shuotian Cheng <[email protected]> | ||
|
||
Support newer kernel and remove eeprom_class dependency | ||
--- | ||
drivers/misc/eeprom/sff_8436_eeprom.c | 27 +++++++-------------------- | ||
include/linux/i2c/sff-8436.h | 2 -- | ||
2 files changed, 7 insertions(+), 22 deletions(-) | ||
drivers/misc/eeprom/sff_8436_eeprom.c | 16 ++-------------- | ||
include/linux/i2c/sff-8436.h | 2 -- | ||
2 files changed, 2 insertions(+), 16 deletions(-) | ||
|
||
diff --git a/drivers/misc/eeprom/sff_8436_eeprom.c b/drivers/misc/eeprom/sff_8436_eeprom.c | ||
index 0b6bf31..f5627bf 100644 | ||
index 3be14d2..bf321a6 100644 | ||
--- a/drivers/misc/eeprom/sff_8436_eeprom.c | ||
+++ b/drivers/misc/eeprom/sff_8436_eeprom.c | ||
@@ -82,7 +82,6 @@ | ||
@@ -85,7 +85,6 @@ | ||
#include <linux/of.h> | ||
#include <linux/i2c.h> | ||
#include <linux/i2c/sff-8436.h> | ||
-#include <linux/eeprom_class.h> | ||
|
||
#include <linux/types.h> | ||
#include <linux/memory.h> | ||
@@ -116,7 +115,6 @@ struct sff_8436_data { | ||
@@ -130,7 +129,6 @@ struct sff_8436_data { | ||
unsigned num_addresses; | ||
|
||
u8 data[SFF_8436_EEPROM_SIZE]; | ||
- struct eeprom_device *eeprom_dev; | ||
|
||
struct i2c_client *client[]; | ||
}; | ||
@@ -421,10 +419,9 @@ static ssize_t sff_8436_eeprom_write(struct sff_8436_data *sff_8436, const char | ||
{ | ||
struct i2c_client *client = sff_8436->client[0]; | ||
struct i2c_msg msg; | ||
- ssize_t status; | ||
unsigned long timeout, write_time; | ||
unsigned next_page; | ||
- int i = 0; | ||
+ int status, i = 0; | ||
|
||
/* write max is at most a page */ | ||
if (count > sff_8436->write_max) | ||
@@ -528,7 +525,7 @@ static ssize_t sff_8436_eeprom_update_client(struct sff_8436_data *sff_8436, | ||
page = sff_8436_translate_offset(sff_8436, &phy_offset); | ||
|
||
dev_dbg(&client->dev, | ||
- "sff_8436_eeprom_update_client off %lld page:%d phy_offset:%lld, count:%d, opcode:%d\n", | ||
+ "sff_8436_eeprom_update_client off %lld page:%d phy_offset:%lld, count:%zu, opcode:%d\n", | ||
off, page, phy_offset, count, opcode); | ||
if (page > 0) { | ||
ret = sff_8436_write_page_reg(sff_8436, page); | ||
@@ -705,18 +702,18 @@ static ssize_t sff_8436_read_write(struct sff_8436_data *sff_8436, | ||
pending_len = pending_len - page_len; | ||
|
||
dev_dbg(&client->dev, | ||
- "sff_read off %lld len %d page_start_offset %lld page_offset %lld page_len %d pending_len %d\n", | ||
+ "sff_read off %lld len %zu page_start_offset %lld page_offset %lld page_len %zu pending_len %zu\n", | ||
off, len, page_start_offset, page_offset, page_len, pending_len); | ||
|
||
/* Refresh the data from offset for specified len */ | ||
ret = sff_8436_eeprom_update_client(sff_8436, page_offset, page_len, opcode); | ||
if (ret != page_len) { | ||
if (err_timeout) { | ||
- dev_dbg(&client->dev, "sff_8436_update_client for %s page %d page_offset %lld page_len %d failed %d!\n", | ||
+ dev_dbg(&client->dev, "sff_8436_update_client for %s page %d page_offset %lld page_len %zu failed %d!\n", | ||
(page ? "Upper" : "Lower"), (page ? (page-1) : page), page_offset, page_len, ret); | ||
goto err; | ||
} else { | ||
- dev_err(&client->dev, "sff_8436_update_client for %s page %d page_offset %lld page_len %d failed %d!\n", | ||
+ dev_err(&client->dev, "sff_8436_update_client for %s page %d page_offset %lld page_len %zu failed %d!\n", | ||
(page ? "Upper" : "Lower"), (page ? (page-1) : page), page_offset, page_len, ret); | ||
} | ||
} | ||
@@ -780,15 +777,13 @@ static ssize_t sff_8436_macc_write(struct memory_accessor *macc, const char *buf | ||
/* Config variable to support SFF-8472/SFP+ standard */ | ||
int sfp_compat; | ||
@@ -955,7 +953,7 @@ static ssize_t sff_8436_macc_write(struct memory_accessor *macc, | ||
|
||
/*-------------------------------------------------------------------------*/ | ||
|
||
-static int __devexit sff_8436_remove(struct i2c_client *client) | ||
+static int sff_8436_remove(struct i2c_client *client) | ||
{ | ||
struct sff_8436_data *sff_8436; | ||
|
||
sff_8436 = i2c_get_clientdata(client); | ||
sysfs_remove_bin_file(&client->dev.kobj, &sff_8436->bin); | ||
int i; | ||
@@ -967,8 +965,6 @@ static int __devexit sff_8436_remove(struct i2c_client *client) | ||
for (i = 1; i < sff_8436->num_addresses; i++) | ||
i2c_unregister_device(sff_8436->client[i]); | ||
|
||
- eeprom_device_unregister(sff_8436->eeprom_dev); | ||
- | ||
kfree(sff_8436->writebuf); | ||
kfree(sff_8436); | ||
return 0; | ||
@@ -821,7 +816,6 @@ static int sff_8436_eeprom_probe(struct i2c_client *client, | ||
@@ -1050,7 +1046,6 @@ static int sff_8436_eeprom_probe(struct i2c_client *client, | ||
|
||
chip.setup = NULL; | ||
chip.context = NULL; | ||
- chip.eeprom_data = NULL; | ||
} | ||
|
||
if (!is_power_of_2(chip.byte_len)) | ||
@@ -923,13 +917,6 @@ static int sff_8436_eeprom_probe(struct i2c_client *client, | ||
if (err) | ||
@@ -1182,13 +1177,6 @@ static int sff_8436_eeprom_probe(struct i2c_client *client, | ||
dev_err(&client->dev, "failed to create sysfs attribute group.\n"); | ||
goto err_struct; | ||
|
||
- sff_8436->eeprom_dev = eeprom_device_register(&client->dev, chip.eeprom_data); | ||
} | ||
- sff_8436->eeprom_dev = eeprom_device_register(&client->dev, | ||
- chip.eeprom_data); | ||
- if (IS_ERR(sff_8436->eeprom_dev)) { | ||
- dev_err(&client->dev, "error registering eeprom device.\n"); | ||
- err = PTR_ERR(sff_8436->eeprom_dev); | ||
- goto err_sysfs_cleanup; | ||
- } | ||
- | ||
i2c_set_clientdata(client, sff_8436); | ||
|
||
dev_info(&client->dev, "%zu byte %s EEPROM, %s\n", | ||
@@ -968,7 +955,7 @@ static struct i2c_driver sff_8436_driver = { | ||
@@ -1235,7 +1223,7 @@ static struct i2c_driver sff_8436_driver = { | ||
.owner = THIS_MODULE, | ||
}, | ||
.probe = sff_8436_eeprom_probe, | ||
|
@@ -139,3 +94,6 @@ index cd46896..4df48ad 100644 | |
}; | ||
|
||
#endif /* _LINUX_SFF_8436_H */ | ||
-- | ||
2.7.4 | ||
|
Oops, something went wrong.