Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: MIT */
0002 #ifndef __NVBIOS_VOLT_H__
0003 #define __NVBIOS_VOLT_H__
0004 
0005 enum nvbios_volt_type {
0006     NVBIOS_VOLT_GPIO = 0,
0007     NVBIOS_VOLT_PWM,
0008 };
0009 
0010 struct nvbios_volt {
0011     enum nvbios_volt_type type;
0012     u32 min;
0013     u32 max;
0014     u32 base;
0015 
0016     /* GPIO mode */
0017     bool ranged;
0018     u8   vidmask;
0019     s16  step;
0020 
0021     /* PWM mode */
0022     u32 pwm_freq;
0023     u32 pwm_range;
0024 };
0025 
0026 u32 nvbios_volt_table(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len);
0027 u32 nvbios_volt_parse(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len,
0028               struct nvbios_volt *);
0029 
0030 struct nvbios_volt_entry {
0031     u32 voltage;
0032     u8  vid;
0033 };
0034 
0035 u32 nvbios_volt_entry(struct nvkm_bios *, int idx, u8 *ver, u8 *len);
0036 u32 nvbios_volt_entry_parse(struct nvkm_bios *, int idx, u8 *ver, u8 *len,
0037                 struct nvbios_volt_entry *);
0038 #endif