162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * arch/parisc/mm/ioremap.c
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * (C) Copyright 1995 1996 Linus Torvalds
662306a36Sopenharmony_ci * (C) Copyright 2001-2019 Helge Deller <deller@gmx.de>
762306a36Sopenharmony_ci * (C) Copyright 2005 Kyle McMartin <kyle@parisc-linux.org>
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <linux/vmalloc.h>
1162306a36Sopenharmony_ci#include <linux/errno.h>
1262306a36Sopenharmony_ci#include <linux/module.h>
1362306a36Sopenharmony_ci#include <linux/io.h>
1462306a36Sopenharmony_ci#include <linux/mm.h>
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_civoid __iomem *ioremap_prot(phys_addr_t phys_addr, size_t size,
1762306a36Sopenharmony_ci			   unsigned long prot)
1862306a36Sopenharmony_ci{
1962306a36Sopenharmony_ci#ifdef CONFIG_EISA
2062306a36Sopenharmony_ci	unsigned long end = phys_addr + size - 1;
2162306a36Sopenharmony_ci	/* Support EISA addresses */
2262306a36Sopenharmony_ci	if ((phys_addr >= 0x00080000 && end < 0x000fffff) ||
2362306a36Sopenharmony_ci	    (phys_addr >= 0x00500000 && end < 0x03bfffff))
2462306a36Sopenharmony_ci		phys_addr |= F_EXTEND(0xfc000000);
2562306a36Sopenharmony_ci#endif
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci	/*
2862306a36Sopenharmony_ci	 * Don't allow anybody to remap normal RAM that we're using..
2962306a36Sopenharmony_ci	 */
3062306a36Sopenharmony_ci	if (phys_addr < virt_to_phys(high_memory)) {
3162306a36Sopenharmony_ci		char *t_addr, *t_end;
3262306a36Sopenharmony_ci		struct page *page;
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci		t_addr = __va(phys_addr);
3562306a36Sopenharmony_ci		t_end = t_addr + (size - 1);
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci		for (page = virt_to_page(t_addr);
3862306a36Sopenharmony_ci		     page <= virt_to_page(t_end); page++) {
3962306a36Sopenharmony_ci			if(!PageReserved(page))
4062306a36Sopenharmony_ci				return NULL;
4162306a36Sopenharmony_ci		}
4262306a36Sopenharmony_ci	}
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci	return generic_ioremap_prot(phys_addr, size, __pgprot(prot));
4562306a36Sopenharmony_ci}
4662306a36Sopenharmony_ciEXPORT_SYMBOL(ioremap_prot);
47