Linux Audio

Check our new training course

Loading...
v4.10.11
 
 1/*
 2 * Copyright (C) 2015 Synopsys, Inc. (www.synopsys.com)
 3 *
 4 * This program is free software; you can redistribute it and/or modify
 5 * it under the terms of the GNU General Public License version 2 as
 6 * published by the Free Software Foundation.
 7 *
 8 */
 9
10#ifndef _ASM_HIGHMEM_H
11#define _ASM_HIGHMEM_H
12
13#ifdef CONFIG_HIGHMEM
14
15#include <uapi/asm/page.h>
16#include <asm/kmap_types.h>
 
 
 
17
18/* start after vmalloc area */
19#define FIXMAP_BASE		(PAGE_OFFSET - FIXMAP_SIZE - PKMAP_SIZE)
20#define FIXMAP_SIZE		PGDIR_SIZE	/* only 1 PGD worth */
21#define KM_TYPE_NR		((FIXMAP_SIZE >> PAGE_SHIFT)/NR_CPUS)
22#define FIXMAP_ADDR(nr)		(FIXMAP_BASE + ((nr) << PAGE_SHIFT))
 
 
 
 
 
 
 
 
 
 
23
24/* start after fixmap area */
25#define PKMAP_BASE		(FIXMAP_BASE + FIXMAP_SIZE)
26#define PKMAP_SIZE		PGDIR_SIZE
27#define LAST_PKMAP		(PKMAP_SIZE >> PAGE_SHIFT)
28#define LAST_PKMAP_MASK		(LAST_PKMAP - 1)
29#define PKMAP_ADDR(nr)		(PKMAP_BASE + ((nr) << PAGE_SHIFT))
30#define PKMAP_NR(virt)		(((virt) - PKMAP_BASE) >> PAGE_SHIFT)
31
32#define kmap_prot		PAGE_KERNEL
33
34
35#include <asm/cacheflush.h>
36
37extern void *kmap(struct page *page);
38extern void *kmap_high(struct page *page);
39extern void *kmap_atomic(struct page *page);
40extern void __kunmap_atomic(void *kvaddr);
41extern void kunmap_high(struct page *page);
42
43extern void kmap_init(void);
44
 
 
 
45static inline void flush_cache_kmaps(void)
46{
47	flush_cache_all();
48}
49
50static inline void kunmap(struct page *page)
51{
52	BUG_ON(in_interrupt());
53	if (!PageHighMem(page))
54		return;
55	kunmap_high(page);
56}
57
58
59#endif
60
61#endif
v6.13.7
 1/* SPDX-License-Identifier: GPL-2.0-only */
 2/*
 3 * Copyright (C) 2015 Synopsys, Inc. (www.synopsys.com)
 
 
 
 
 
 4 */
 5
 6#ifndef _ASM_HIGHMEM_H
 7#define _ASM_HIGHMEM_H
 8
 9#ifdef CONFIG_HIGHMEM
10
11#include <uapi/asm/page.h>
12#include <asm/kmap_size.h>
13
14#define FIXMAP_SIZE		PGDIR_SIZE
15#define PKMAP_SIZE		PGDIR_SIZE
16
17/* start after vmalloc area */
18#define FIXMAP_BASE		(PAGE_OFFSET - FIXMAP_SIZE - PKMAP_SIZE)
19
20#define FIX_KMAP_SLOTS		(KM_MAX_IDX * NR_CPUS)
21#define FIX_KMAP_BEGIN		(0UL)
22#define FIX_KMAP_END		((FIX_KMAP_BEGIN + FIX_KMAP_SLOTS) - 1)
23
24#define FIXADDR_TOP		(FIXMAP_BASE + (FIX_KMAP_END << PAGE_SHIFT))
25
26/*
27 * This should be converted to the asm-generic version, but of course this
28 * is needlessly different from all other architectures. Sigh - tglx
29 */
30#define __fix_to_virt(x)	(FIXADDR_TOP - ((x) << PAGE_SHIFT))
31#define __virt_to_fix(x)	(((FIXADDR_TOP - ((x) & PAGE_MASK))) >> PAGE_SHIFT)
32
33/* start after fixmap area */
34#define PKMAP_BASE		(FIXMAP_BASE + FIXMAP_SIZE)
 
35#define LAST_PKMAP		(PKMAP_SIZE >> PAGE_SHIFT)
36#define LAST_PKMAP_MASK		(LAST_PKMAP - 1)
37#define PKMAP_ADDR(nr)		(PKMAP_BASE + ((nr) << PAGE_SHIFT))
38#define PKMAP_NR(virt)		(((virt) - PKMAP_BASE) >> PAGE_SHIFT)
39
 
 
 
40#include <asm/cacheflush.h>
41
 
 
 
 
 
 
42extern void kmap_init(void);
43
44#define arch_kmap_local_post_unmap(vaddr)			\
45	local_flush_tlb_kernel_range(vaddr, vaddr + PAGE_SIZE)
46
47static inline void flush_cache_kmaps(void)
48{
49	flush_cache_all();
50}
 
 
 
 
 
 
 
 
 
 
51#endif
52
53#endif