The bulk SPDX addition made all these files into GPL-2.0 licensed files. However the remainder of the project is MIT-licensed, these files (primarily header files) were simply missing the boiler plate and got caught up in the global update. Fixes: b24413180f5 (License cleanup: add SPDX GPL-2.0 license identifier to files with no license) Signed-off-by: Ilia Mirkin <imirkin@alum.mit.edu> Acked-by: Emil Velikov <emil.l.velikov@gmail.com> Acked-by: Karol Herbst <kherbst@redhat.com> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
46 lines
1.2 KiB
C
46 lines
1.2 KiB
C
/* SPDX-License-Identifier: MIT */
|
|
#ifndef __NVKM_VOLT_H__
|
|
#define __NVKM_VOLT_H__
|
|
#include <core/subdev.h>
|
|
|
|
struct nvkm_volt {
|
|
const struct nvkm_volt_func *func;
|
|
struct nvkm_subdev subdev;
|
|
|
|
u8 vid_mask;
|
|
u8 vid_nr;
|
|
struct {
|
|
u32 uv;
|
|
u8 vid;
|
|
} vid[256];
|
|
|
|
u32 max_uv;
|
|
u32 min_uv;
|
|
|
|
/*
|
|
* These are fully functional map entries creating a sw ceiling for
|
|
* the voltage. These all can describe different kind of curves, so
|
|
* that for any given temperature a different one can return the lowest
|
|
* value of all three.
|
|
*/
|
|
u8 max0_id;
|
|
u8 max1_id;
|
|
u8 max2_id;
|
|
|
|
int speedo;
|
|
};
|
|
|
|
int nvkm_volt_map(struct nvkm_volt *volt, u8 id, u8 temperature);
|
|
int nvkm_volt_map_min(struct nvkm_volt *volt, u8 id);
|
|
int nvkm_volt_get(struct nvkm_volt *);
|
|
int nvkm_volt_set_id(struct nvkm_volt *, u8 id, u8 min_id, u8 temp,
|
|
int condition);
|
|
|
|
int nv40_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
int gf100_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
int gf117_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
int gk104_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
int gk20a_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
int gm20b_volt_new(struct nvkm_device *, int, struct nvkm_volt **);
|
|
#endif
|