2019-10-09 19:47:46 -05:00
|
|
|
/*
|
|
|
|
* mc24lc64t.c - driver for Microchip 24LC64T
|
|
|
|
*
|
|
|
|
* Copyright (C) 2017 Celestica Corp.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/slab.h>
|
|
|
|
#include <linux/i2c.h>
|
|
|
|
#include <linux/mutex.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/delay.h>
|
|
|
|
#include <linux/jiffies.h>
|
|
|
|
|
|
|
|
#define EEPROM_SIZE 8192 //mc24lt64t eeprom size in bytes.
|
|
|
|
|
|
|
|
struct mc24lc64t_data {
|
|
|
|
struct mutex update_lock;
|
|
|
|
};
|
|
|
|
|
|
|
|
static ssize_t mc24lc64t_read(struct file *filp, struct kobject *kobj,
|
|
|
|
struct bin_attribute *bin_attr,
|
|
|
|
char *buf, loff_t off, size_t count)
|
|
|
|
{
|
|
|
|
struct i2c_client *client = kobj_to_i2c_client(kobj);
|
|
|
|
struct mc24lc64t_data *drvdata = i2c_get_clientdata(client);
|
|
|
|
unsigned long timeout, read_time, i = 0;
|
|
|
|
int status;
|
|
|
|
|
|
|
|
mutex_lock(&drvdata->update_lock);
|
|
|
|
|
|
|
|
if (i2c_smbus_write_byte_data(client, off>>8, off))
|
|
|
|
{
|
|
|
|
status = -EIO;
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
msleep(1);
|
|
|
|
|
|
|
|
begin:
|
|
|
|
|
|
|
|
if (i < count)
|
|
|
|
{
|
|
|
|
timeout = jiffies + msecs_to_jiffies(25); /* 25 mS timeout*/
|
|
|
|
do {
|
|
|
|
read_time = jiffies;
|
|
|
|
|
|
|
|
status = i2c_smbus_read_byte(client);
|
|
|
|
if (status >= 0)
|
|
|
|
{
|
|
|
|
buf[i++] = status;
|
|
|
|
goto begin;
|
|
|
|
}
|
|
|
|
} while (time_before(read_time, timeout));
|
|
|
|
|
|
|
|
status = -ETIMEDOUT;
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
status = count;
|
|
|
|
|
|
|
|
exit:
|
|
|
|
mutex_unlock(&drvdata->update_lock);
|
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static ssize_t mc24lc64t_write (struct file *filp, struct kobject *kobj,
|
|
|
|
struct bin_attribute *bin_attr,
|
|
|
|
char *buf, loff_t off, size_t count){
|
|
|
|
|
|
|
|
struct i2c_client *client = kobj_to_i2c_client(kobj);
|
|
|
|
struct mc24lc64t_data *drvdata = i2c_get_clientdata(client);
|
|
|
|
unsigned long timeout, write_time, i = 0;
|
|
|
|
int status;
|
|
|
|
u16 value;
|
|
|
|
|
|
|
|
mutex_lock(&drvdata->update_lock);
|
|
|
|
|
|
|
|
begin:
|
|
|
|
if (i < count){
|
|
|
|
timeout = jiffies + msecs_to_jiffies(25); /* 25 mS timeout*/
|
|
|
|
value = (buf[i] << 8 | ( off &0xff));
|
|
|
|
do {
|
|
|
|
write_time = jiffies;
|
|
|
|
status = i2c_smbus_write_word_data(client, off>>8, value);
|
|
|
|
if (status >= 0)
|
|
|
|
{
|
|
|
|
// increase offset
|
|
|
|
off++;
|
|
|
|
// increase buffer index
|
|
|
|
i++;
|
|
|
|
goto begin;
|
|
|
|
}
|
|
|
|
} while (time_before(write_time, timeout));
|
|
|
|
status = -ETIMEDOUT;
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
status = count;
|
|
|
|
|
|
|
|
exit:
|
|
|
|
mutex_unlock(&drvdata->update_lock);
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static struct bin_attribute mc24lc64t_bit_attr = {
|
|
|
|
.attr = {
|
|
|
|
.name = "eeprom",
|
|
|
|
.mode = S_IRUGO | S_IWUGO,
|
|
|
|
},
|
|
|
|
.size = EEPROM_SIZE,
|
|
|
|
.read = mc24lc64t_read,
|
|
|
|
.write = mc24lc64t_write,
|
|
|
|
};
|
|
|
|
|
|
|
|
static int mc24lc64t_probe(struct i2c_client *client,
|
|
|
|
const struct i2c_device_id *id)
|
|
|
|
{
|
|
|
|
struct i2c_adapter *adapter = client->adapter;
|
|
|
|
struct mc24lc64t_data *drvdata;
|
|
|
|
int err;
|
|
|
|
|
|
|
|
if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_WRITE_BYTE_DATA
|
|
|
|
| I2C_FUNC_SMBUS_READ_BYTE))
|
|
|
|
return -EPFNOSUPPORT;
|
|
|
|
|
|
|
|
if (!(drvdata = devm_kzalloc(&client->dev,
|
|
|
|
sizeof(struct mc24lc64t_data), GFP_KERNEL)))
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
i2c_set_clientdata(client, drvdata);
|
|
|
|
mutex_init(&drvdata->update_lock);
|
|
|
|
|
|
|
|
err = sysfs_create_bin_file(&client->dev.kobj, &mc24lc64t_bit_attr);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
[PR:16737, PR:16739] platform-modules: pddf, broadcom/cel: adapt for kernel 6.1 and bookworm (#16954)
* sonic-platform-modules-cel: broadcom: adapt for kernel 6.1 and bookworm
The i2c_driver->remove API declaration has been updated to return void instead
of int, as part of cleanup patches in 6.1. More details can be referred from
here: [1]. Update the remove API definition in the modules accordingly and
cleanup variables that go unused from the remove API.
Update python build commands for bookworm. The packaging based on calling
setup.py is deprecated and using build module/pip utility is the recommended
method for python packaging/installation. Further details can be referred to
from here: [2], [3]. The build module is picky about the package information file,
which needs to be either setup.py or pyproject.toml.
Additionally, fix formatting inconsistencies in debian/changelog reported by
`dh_installchangelogs` during the build.
Tested the changes by compiling the changes as below:
make sonic-slave-bash NOBUSTER=1 NOBULLSEYE=1
sudo dpkg -i target/debs/bookworm/linux-headers-6.1.0-11-2-*.deb
cd platform/broadcom/sonic-platform-modules-cel
KVERSION=6.1.0-11-2-amd64 dpkg-buildpackage
Also verified the python scripts under the sonic-platform-modules-cel with
pyflakes to ensure no new errors are flagged (with exception of unused modules).
References:
[1] - https://github.com/torvalds/linux/commit/ed5c2f5f
[2] - https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.htm
[3] - 0b20a4863 (Update Python build commands for Bookworm, 2023-09-07)
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
* platform/pddf: i2c: adapt for kernel 6.1 and bookworm
* Fixup i2c_driver->remove API due to changes in the function
prototype (ref: [1]).
* Cleanup `MODULE_SUPPORTED_DEVICE` macros that were cleaned up in
the upstream (ref: [2]).
* Sanitize python packaging and installation using the `build` module
instead of calling the setup.py directly (ref: [3]. [4]).
Tested the changes by compiling pddf module as below:
make sonic-slave-bash NOBUSTER=1 NOBULLSEYE=1
sudo dpkg -i target/debs/bookworm/linux-headers-6.1.0-11-2-*.deb
cd platform/pddf/i2c
KVERSION=6.1.0-11-2-amd64 dpkg-buildpackage
References:
[1] - https://github.com/torvalds/linux/commit/ed5c2f5f
[2] - https://github.com/torvalds/linux/commit/6417f031
[2] - https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.htm
[3] - 0b20a4863 (Update Python build commands for Bookworm, 2023-09-07)
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
* platform/broadcom: include platform-modules-cel in builds
With pddf modules patched for 6.1, platform-modules-cel can be compiled
and included in the final image.
Testing by building sonic-broadcom.bin/sonic-broadcom-dnx.bin.
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
* pddf/i2c: revert correct rootdir for pip install
The pip install directory has been set to test-pkg1/ for testing the build and
incorrectly retained as is. Revert this to the correct path $(PACKAGE_PRE_NAME).
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
* platform/broadcom: include pddf/modules-cel in the base package
Without this change, the modules were built but not packaged in the final .bin.
The final sonic-broadcom.bin has been tested for bootup on Celestica's
Silverstone platform.
admin@sonic:~$ uname -a
Linux sonic 6.1.0-11-2-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.38-4 (2023-08-08) x86_64 GNU/Linux
admin@sonic:~$ show platform summary
Platform: x86_64-cel_silverstone-r0
HwSKU: Silverstone
ASIC: broadcom
ASIC Count: 1
Serial Number: R4009B2F062504LK200024
Model Number: N/A
Hardware Revision: N/A
admin@sonic:~$ show version | head
SONiC Software Version: SONiC.g0aad6c67c-rachandr
SONiC OS Version: 12
Distribution: Debian 12.2
Kernel: 6.1.0-11-2-amd64
Build commit: 0aad6c67c
Build date: Thu Oct 26 07:13:47 UTC 2023
Built by: rachandr@AZUHPS14
Platform: x86_64-cel_silverstone-r0
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
---------
Signed-off-by: Ramasamy Chandramouli <rachandr@celestica.com>
2023-09-08 17:59:48 -05:00
|
|
|
static void mc24lc64t_remove(struct i2c_client *client)
|
2019-10-09 19:47:46 -05:00
|
|
|
{
|
|
|
|
sysfs_remove_bin_file(&client->dev.kobj, &mc24lc64t_bit_attr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static const struct i2c_device_id mc24lc64t_id[] = {
|
|
|
|
{ "24lc64t", 0 },
|
|
|
|
{ }
|
|
|
|
};
|
|
|
|
MODULE_DEVICE_TABLE(i2c, mc24lc64t_id);
|
|
|
|
|
|
|
|
static struct i2c_driver mc24lc64t_driver = {
|
|
|
|
.driver = {
|
|
|
|
.name = "mc24lc64t",
|
|
|
|
.owner = THIS_MODULE,
|
|
|
|
},
|
|
|
|
.probe = mc24lc64t_probe,
|
|
|
|
.remove = mc24lc64t_remove,
|
|
|
|
.id_table = mc24lc64t_id,
|
|
|
|
};
|
|
|
|
|
|
|
|
module_i2c_driver(mc24lc64t_driver);
|
|
|
|
|
|
|
|
MODULE_AUTHOR("Abhisit Sangjan <asang@celestica.com>");
|
|
|
|
MODULE_DESCRIPTION("Microchip 24LC64T Driver");
|
|
|
|
MODULE_LICENSE("GPL");
|