Linux Audio

Check our new training course

Embedded Linux Audio

Check our new training course
with Creative Commons CC-BY-SA
lecture materials

Bootlin logo

Elixir Cross Referencer

Loading...
/*
 * linux/include/asm-arm/arch-rpc/mmap.h
 *
 * Copyright (C) 1996 Russell King
 */

#define HAVE_MAP_VID_MEM
#define SAFE_ADDR 0x00000000	/* ROM */

unsigned long map_screen_mem(unsigned long log_start, unsigned long kmem, int update)
{
	static int updated = 0;
	unsigned long address;
	pgd_t *pgd;

	if (updated)
		return 0;
	updated = update;

	address = SCREEN_START | PMD_TYPE_SECT | PMD_DOMAIN(DOMAIN_KERNEL) | PMD_SECT_AP_WRITE;
	pgd = swapper_pg_dir + (SCREEN2_BASE >> PGDIR_SHIFT);
	pgd_val(pgd[0]) = address;
	pgd_val(pgd[1]) = address + (1 << PGDIR_SHIFT);

	if (update) {
		unsigned long pgtable = PAGE_ALIGN(kmem), *p;
		int i;

		memzero ((void *)pgtable, 4096);
		
		pgd_val(pgd[-2]) = virt_to_phys(pgtable) | PMD_TYPE_TABLE | PMD_DOMAIN(DOMAIN_KERNEL);
		pgd_val(pgd[-1]) = virt_to_phys(pgtable + PTRS_PER_PTE*4) | PMD_TYPE_TABLE | PMD_DOMAIN(DOMAIN_KERNEL);
		p = (unsigned long *)pgtable;

		i = PTRS_PER_PTE * 2 - ((SCREEN1_END - log_start) >> PAGE_SHIFT);
		address = SCREEN_START | PTE_TYPE_SMALL | PTE_AP_WRITE;

		while (i < PTRS_PER_PTE * 2) {
			p[i++] = address;
			address += PAGE_SIZE;
		}

		flush_page_to_ram(pgtable);

		kmem = pgtable + PAGE_SIZE;
	}
	return kmem;
}