| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef __NVBIOS_VOLT_H__ |
| #define __NVBIOS_VOLT_H__ |
| |
| enum nvbios_volt_type { |
| NVBIOS_VOLT_GPIO = 0, |
| NVBIOS_VOLT_PWM, |
| }; |
| |
| struct nvbios_volt { |
| enum nvbios_volt_type type; |
| u32 min; |
| u32 max; |
| u32 base; |
| |
| /* GPIO mode */ |
| bool ranged; |
| u8 vidmask; |
| s16 step; |
| |
| /* PWM mode */ |
| u32 pwm_freq; |
| u32 pwm_range; |
| }; |
| |
| 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, |
| struct nvbios_volt *); |
| |
| struct nvbios_volt_entry { |
| u32 voltage; |
| u8 vid; |
| }; |
| |
| 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, |
| struct nvbios_volt_entry *); |
| #endif |