Merge tag 'regulator-v4.11' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie...
[sfrench/cifs-2.6.git] / drivers / gpu / drm / nouveau / include / nvkm / subdev / bios / volt.h
1 #ifndef __NVBIOS_VOLT_H__
2 #define __NVBIOS_VOLT_H__
3
4 enum nvbios_volt_type {
5         NVBIOS_VOLT_GPIO = 0,
6         NVBIOS_VOLT_PWM,
7 };
8
9 struct nvbios_volt {
10         enum nvbios_volt_type type;
11         u32 min;
12         u32 max;
13         u32 base;
14
15         /* GPIO mode */
16         bool ranged;
17         u8   vidmask;
18         s16  step;
19
20         /* PWM mode */
21         u32 pwm_freq;
22         u32 pwm_range;
23 };
24
25 u32 nvbios_volt_table(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len);
26 u32 nvbios_volt_parse(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len,
27                       struct nvbios_volt *);
28
29 struct nvbios_volt_entry {
30         u32 voltage;
31         u8  vid;
32 };
33
34 u32 nvbios_volt_entry(struct nvkm_bios *, int idx, u8 *ver, u8 *len);
35 u32 nvbios_volt_entry_parse(struct nvkm_bios *, int idx, u8 *ver, u8 *len,
36                             struct nvbios_volt_entry *);
37 #endif