mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

This commit reworks the RAM detection algorithm, using RAM-per-LTC to determine whether a board has a mixed-memory configuration instead of using RAM-per-FBPA. I'm not certain the algorithm is perfect, but it should handle all currently known configurations in the very least. This should fix GTX 970 boards with 4GiB of RAM where the last 512MiB isn't fully accessible, as well as only detecting half the VRAM on GF108 boards. As a nice side-effect, GP10x memory detection now reuses the majority of the code from earlier chipsets. Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
79 lines
3.3 KiB
C
79 lines
3.3 KiB
C
#ifndef __NVKM_FB_RAM_PRIV_H__
|
|
#define __NVKM_FB_RAM_PRIV_H__
|
|
#include "priv.h"
|
|
|
|
int nvkm_ram_ctor(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
enum nvkm_ram_type, u64 size, u32 tags,
|
|
struct nvkm_ram *);
|
|
int nvkm_ram_new_(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
enum nvkm_ram_type, u64 size, u32 tags,
|
|
struct nvkm_ram **);
|
|
void nvkm_ram_del(struct nvkm_ram **);
|
|
int nvkm_ram_init(struct nvkm_ram *);
|
|
|
|
extern const struct nvkm_ram_func nv04_ram_func;
|
|
|
|
int nv50_ram_ctor(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
struct nvkm_ram *);
|
|
int nv50_ram_get(struct nvkm_ram *, u64, u32, u32, u32, struct nvkm_mem **);
|
|
void nv50_ram_put(struct nvkm_ram *, struct nvkm_mem **);
|
|
void __nv50_ram_put(struct nvkm_ram *, struct nvkm_mem *);
|
|
|
|
int gf100_ram_new_(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
struct nvkm_ram **);
|
|
int gf100_ram_ctor(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
struct nvkm_ram *);
|
|
u32 gf100_ram_probe_fbp(const struct nvkm_ram_func *,
|
|
struct nvkm_device *, int, int *);
|
|
u32 gf100_ram_probe_fbp_amount(const struct nvkm_ram_func *, u32,
|
|
struct nvkm_device *, int, int *);
|
|
u32 gf100_ram_probe_fbpa_amount(struct nvkm_device *, int);
|
|
int gf100_ram_get(struct nvkm_ram *, u64, u32, u32, u32, struct nvkm_mem **);
|
|
void gf100_ram_put(struct nvkm_ram *, struct nvkm_mem **);
|
|
int gf100_ram_init(struct nvkm_ram *);
|
|
int gf100_ram_calc(struct nvkm_ram *, u32);
|
|
int gf100_ram_prog(struct nvkm_ram *);
|
|
void gf100_ram_tidy(struct nvkm_ram *);
|
|
|
|
u32 gf108_ram_probe_fbp_amount(const struct nvkm_ram_func *, u32,
|
|
struct nvkm_device *, int, int *);
|
|
|
|
int gk104_ram_new_(const struct nvkm_ram_func *, struct nvkm_fb *,
|
|
struct nvkm_ram **);
|
|
void *gk104_ram_dtor(struct nvkm_ram *);
|
|
int gk104_ram_init(struct nvkm_ram *);
|
|
int gk104_ram_calc(struct nvkm_ram *, u32);
|
|
int gk104_ram_prog(struct nvkm_ram *);
|
|
void gk104_ram_tidy(struct nvkm_ram *);
|
|
|
|
u32 gm107_ram_probe_fbp(const struct nvkm_ram_func *,
|
|
struct nvkm_device *, int, int *);
|
|
|
|
u32 gm200_ram_probe_fbp_amount(const struct nvkm_ram_func *, u32,
|
|
struct nvkm_device *, int, int *);
|
|
|
|
/* RAM type-specific MR calculation routines */
|
|
int nvkm_sddr2_calc(struct nvkm_ram *);
|
|
int nvkm_sddr3_calc(struct nvkm_ram *);
|
|
int nvkm_gddr3_calc(struct nvkm_ram *);
|
|
int nvkm_gddr5_calc(struct nvkm_ram *, bool nuts);
|
|
|
|
int nv04_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv10_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv1a_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv20_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv40_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv41_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv44_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv49_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv4e_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int nv50_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gt215_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int mcp77_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gf100_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gf108_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gk104_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gm107_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gm200_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
int gp100_ram_new(struct nvkm_fb *, struct nvkm_ram **);
|
|
#endif
|