Skip to content

Commit edc3acd

Browse files
author
Jostar Yang
committed
[as9716_32d] Modify to support new PSU SN
1 parent dd1644b commit edc3acd

File tree

1 file changed

+33
-7
lines changed

1 file changed

+33
-7
lines changed

platform/broadcom/sonic-platform-modules-accton/as9716-32d/modules/accton_as9716_32d_psu.c

Lines changed: 33 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@
3535
#include <linux/dmi.h>
3636

3737
#define MAX_MODEL_NAME 16
38-
#define MAX_SERIAL_NUMBER 19
38+
#define MAX_SERIAL_NUMBER 20
3939

4040
static ssize_t show_status(struct device *dev, struct device_attribute *da, char *buf);
4141
static ssize_t show_string(struct device *dev, struct device_attribute *da, char *buf);
@@ -280,18 +280,45 @@ static struct as9716_32d_psu_data *as9716_32d_psu_update_device(struct device *d
280280
data->model_name[0] = '\0';
281281
dev_dbg(&client->dev, "unable to read model name from (0x%x)\n", client->addr);
282282
}
283-
else {
284-
data->model_name[ARRAY_SIZE(data->model_name)-1] = '\0';
283+
else
284+
{
285+
if (!strncmp(data->model_name, "FSH082", strlen("FSH082")))
286+
{
287+
data->model_name[strlen("FSH082")]='\0';
288+
}
289+
else if (!strncmp(data->model_name, "YESM1300", strlen("YESM1300")))
290+
{
291+
if (data->model_name[9]=='A' && data->model_name[10]=='M')
292+
{
293+
data->model_name[8]='A';
294+
data->model_name[9]='M';
295+
data->model_name[strlen("YESM1300AM")]='\0';
296+
}
297+
else
298+
data->model_name[strlen("YESM1300")]='\0';
299+
}
300+
else if (!strncmp(data->model_name, "YM-2651Y", strlen("YM-2651Y")))
301+
{
302+
data->model_name[strlen("YM-2651Y")]='\0';
303+
}
304+
else
305+
data->model_name[ARRAY_SIZE(data->model_name)-1] = '\0';
285306

286307
}
287-
/* Read from offset 0x2e ~ 0x3d (16 bytes) */
288-
status = as9716_32d_psu_read_block(client, 0x2e,data->serial_number, MAX_SERIAL_NUMBER);
308+
/* Read from offset 0x35 ~ 0x47 */
309+
status = as9716_32d_psu_read_block(client, 0x35,data->serial_number, MAX_SERIAL_NUMBER);
289310
if (status < 0)
290311
{
291312
data->serial_number[0] = '\0';
292313
dev_dbg(&client->dev, "unable to read model name from (0x%x) offset(0x2e)\n", client->addr);
293314
}
294-
data->serial_number[MAX_SERIAL_NUMBER-1]='\0';
315+
if (!strncmp(data->model_name, "YESM1300AM", strlen("YESM1300AM"))) /*for YESM1300AM, SN length=19*/
316+
{
317+
data->serial_number[MAX_SERIAL_NUMBER-1]='\0';
318+
}
319+
else /*for FSH082, SN length=18*/
320+
data->serial_number[MAX_SERIAL_NUMBER-2]='\0';
321+
295322
}
296323

297324
data->last_updated = jiffies;
@@ -308,4 +335,3 @@ module_i2c_driver(as9716_32d_psu_driver);
308335
MODULE_AUTHOR("Jostar Yang <[email protected]>");
309336
MODULE_DESCRIPTION("as9716_32d_psu driver");
310337
MODULE_LICENSE("GPL");
311-

0 commit comments

Comments
 (0)