// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
/* Copyright (C) 2017 Netronome Systems, Inc. */
#include <linux/kernel.h>
#include <linux/slab.h>
#include "nfp.h"
#include "nfp_nsp.h"
struct nsp_identify {
u8 version[40];
u8 flags;
u8 br_primary;
u8 br_secondary;
u8 br_nsp;
__le16 primary;
__le16 secondary;
__le16 nsp;
u8 reserved[6];
__le64 sensor_mask;
};
struct nfp_nsp_identify *__nfp_nsp_identify(struct nfp_nsp *nsp)
{
struct nfp_nsp_identify *nspi = NULL;
struct nsp_identify *ni;
int ret;
if (nfp_nsp_get_abi_ver_minor(nsp) < 15)
return NULL;
ni = kzalloc(sizeof(*ni), GFP_KERNEL);
if (!ni)
return NULL;
ret = nfp_nsp_read_identify(nsp, ni, sizeof(*ni));
if (ret < 0) {
nfp_err(nfp_nsp_cpp(nsp), "reading bsp version failed %d\n",
ret);
goto exit_free;
}
nspi = kzalloc(sizeof(*nspi), GFP_KERNEL);
if (!nspi)
goto exit_free;
memcpy(nspi->version, ni->version, sizeof(nspi->version));
nspi->version[sizeof(nspi->version) - 1] = '\0';
nspi->flags = ni->flags;
nspi->br_primary = ni->br_primary;
nspi->br_secondary = ni->br_secondary;
nspi->br_nsp = ni->br_nsp;
nspi->primary = le16_to_cpu(ni->primary);
nspi->secondary = le16_to_cpu(ni->secondary);
nspi->nsp = le16_to_cpu(ni->nsp);
nspi->sensor_mask = le64_to_cpu(ni->sensor_mask);
exit_free:
kfree(ni);
return nspi;
}
struct nfp_sensors {
__le32 chip_temp;
__le32 assembly_power;
__le32 assembly_12v_power;
__le32 assembly_3v3_power;
};
int nfp_hwmon_read_sensor(struct nfp_cpp *cpp, enum nfp_nsp_sensor_id id,
long *val)
{
struct nfp_sensors s;
struct nfp_nsp *nsp;
int ret;
nsp = nfp_nsp_open(cpp);
if (IS_ERR(nsp))
return PTR_ERR(nsp);
ret = nfp_nsp_read_sensors(nsp, BIT(id), &s, sizeof(s));
nfp_nsp_close(nsp);
if (ret < 0)
return ret;
switch (id) {
case NFP_SENSOR_CHIP_TEMPERATURE:
*val = le32_to_cpu(s.chip_temp);
break;
case NFP_SENSOR_ASSEMBLY_POWER:
*val = le32_to_cpu(s.assembly_power);
break;
case NFP_SENSOR_ASSEMBLY_12V_POWER:
*val = le32_to_cpu(s.assembly_12v_power);
break;
case NFP_SENSOR_ASSEMBLY_3V3_POWER:
*val = le32_to_cpu(s.assembly_3v3_power);
break;
default:
return -EINVAL;
}
return 0;
}