2019-06-20 00:13:43 +00:00
|
|
|
/* SPDX-License-Identifier: MIT */
|
2013-01-14 22:33:25 +00:00
|
|
|
#ifndef __NVBIOS_VOLT_H__
|
|
|
|
#define __NVBIOS_VOLT_H__
|
2015-09-09 01:05:50 +00:00
|
|
|
|
|
|
|
enum nvbios_volt_type {
|
|
|
|
NVBIOS_VOLT_GPIO = 0,
|
|
|
|
NVBIOS_VOLT_PWM,
|
|
|
|
};
|
|
|
|
|
2013-01-14 22:33:25 +00:00
|
|
|
struct nvbios_volt {
|
2015-09-09 01:05:50 +00:00
|
|
|
enum nvbios_volt_type type;
|
2013-01-14 22:33:25 +00:00
|
|
|
u32 min;
|
|
|
|
u32 max;
|
|
|
|
u32 base;
|
2015-09-09 01:05:50 +00:00
|
|
|
|
|
|
|
/* GPIO mode */
|
2016-07-12 19:36:08 +00:00
|
|
|
bool ranged;
|
|
|
|
u8 vidmask;
|
|
|
|
s16 step;
|
2015-09-09 01:05:50 +00:00
|
|
|
|
|
|
|
/* PWM mode */
|
|
|
|
u32 pwm_freq;
|
|
|
|
u32 pwm_range;
|
2013-01-14 22:33:25 +00:00
|
|
|
};
|
|
|
|
|
2016-11-18 01:18:45 +00:00
|
|
|
u32 nvbios_volt_table(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len);
|
|
|
|
u32 nvbios_volt_parse(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len,
|
2013-01-14 22:33:25 +00:00
|
|
|
struct nvbios_volt *);
|
|
|
|
|
|
|
|
struct nvbios_volt_entry {
|
|
|
|
u32 voltage;
|
|
|
|
u8 vid;
|
|
|
|
};
|
|
|
|
|
2016-11-18 01:18:45 +00:00
|
|
|
u32 nvbios_volt_entry(struct nvkm_bios *, int idx, u8 *ver, u8 *len);
|
|
|
|
u32 nvbios_volt_entry_parse(struct nvkm_bios *, int idx, u8 *ver, u8 *len,
|
2013-01-14 22:33:25 +00:00
|
|
|
struct nvbios_volt_entry *);
|
|
|
|
#endif
|