forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-02-14 796a7ef0befd21e25c2b9e42f53a6d7a4421941d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/* SPDX-License-Identifier: GPL-2.0 */
#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