summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgp102.c
blob: 8550f5e473474bb3d8d224e2dccf3e37efc5a0f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// SPDX-License-Identifier: MIT
#include "ram.h"

#include <subdev/bios.h>

static const struct nvkm_ram_func
gp102_ram = {
};

int
gp102_ram_new(struct nvkm_fb *fb, struct nvkm_ram **pram)
{
	enum nvkm_ram_type type = nvkm_fb_bios_memtype(fb->subdev.device->bios);
	const u32 rsvd_head = ( 256 * 1024); /* vga memory */
	const u32 rsvd_tail = (1024 * 1024); /* vbios etc */
	u64 size = fb->func->vidmem.size(fb);
	int ret;

	ret = nvkm_ram_new_(&gp102_ram, fb, type, size, pram);
	if (ret)
		return ret;

	nvkm_mm_fini(&(*pram)->vram);

	return nvkm_mm_init(&(*pram)->vram, NVKM_RAM_MM_NORMAL,
			    rsvd_head >> NVKM_RAM_MM_SHIFT,
			    (size - rsvd_head - rsvd_tail) >> NVKM_RAM_MM_SHIFT,
			    1);

}