root/drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/perf.h
/* SPDX-License-Identifier: MIT */
#ifndef __NVBIOS_PERF_H__
#define __NVBIOS_PERF_H__
u32 nvbios_perf_table(struct nvkm_bios *, u8 *ver, u8 *hdr,
                      u8 *cnt, u8 *len, u8 *snr, u8 *ssz);

struct nvbios_perfE {
        u8  pstate;
        u8  fanspeed;
        u8  voltage;
        u32 core;
        u32 shader;
        u32 memory;
        u32 vdec;
        u32 disp;
        u32 script;
        u8  pcie_speed;
        u8  pcie_width;
};

u32 nvbios_perf_entry(struct nvkm_bios *, int idx,
                      u8 *ver, u8 *hdr, u8 *cnt, u8 *len);
u32 nvbios_perfEp(struct nvkm_bios *, int idx,
                  u8 *ver, u8 *hdr, u8 *cnt, u8 *len, struct nvbios_perfE *);

struct nvbios_perfS {
        union {
                struct {
                        u32 freq;
                } v40;
        };
};

u32 nvbios_perfSe(struct nvkm_bios *, u32 data, int idx,
                  u8 *ver, u8 *hdr, u8 cnt, u8 len);
u32 nvbios_perfSp(struct nvkm_bios *, u32 data, int idx,
                  u8 *ver, u8 *hdr, u8 cnt, u8 len, struct nvbios_perfS *);

struct nvbios_perf_fan {
        u32 pwm_divisor;
};

int nvbios_perf_fan_parse(struct nvkm_bios *, struct nvbios_perf_fan *);
#endif