OXIESEC PANEL
- Current Dir:
/
/
usr
/
src
/
linux-headers-4.15.0-197
/
arch
/
alpha
/
include
/
asm
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
11/17/2022 06:42:15 AM
rwxr-xr-x
📄
Kbuild
320 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
a.out-core.h
2.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
a.out.h
574 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
agp.h
457 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
agp_backend.h
948 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
asm-offsets.h
35 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
asm-prototypes.h
405 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
atomic.h
9.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
barrier.h
2.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
bitops.h
8.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
bug.h
571 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
bugs.h
294 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cache.h
507 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cacheflush.h
2.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
checksum.h
1.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
cmpxchg.h
1.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
compiler.h
498 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
console.h
1.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_apecs.h
16.91 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_cia.h
15.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_irongate.h
6.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_lca.h
11.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_marvel.h
9.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_mcpcia.h
11.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_polaris.h
2.92 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_t2.h
19.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_titan.h
11.2 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_tsunami.h
8.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
core_wildfire.h
8.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
delay.h
264 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
device.h
129 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
div64.h
31 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
dma-mapping.h
276 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
dma.h
12.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
elf.h
5.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
emergency-restart.h
149 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
err_common.h
3.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
err_ev6.h
116 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
err_ev7.h
4.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
extable.h
1.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
floppy.h
3.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
fpu.h
1.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ftrace.h
12 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
futex.h
1.97 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
gct.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
hardirq.h
223 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
hw_irq.h
302 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
hwrpb.h
6.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
io.h
15.03 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
io_trivial.h
3.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
irq.h
2.31 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
irq_regs.h
34 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
irqflags.h
1.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
jensen.h
8.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
kdebug.h
32 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
kmap_types.h
265 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
linkage.h
256 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
local.h
2.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
local64.h
33 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
machvec.h
3.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mc146818rtc.h
680 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
mce.h
4.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mmu.h
203 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
mmu_context.h
7.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mmzone.h
2.98 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
module.h
329 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
page.h
2.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pal.h
5.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
param.h
284 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
parport.h
536 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
pci.h
2.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
percpu.h
527 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
perf_event.h
105 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
pgalloc.h
1.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pgtable.h
13.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
processor.h
2.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ptrace.h
754 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
rwsem.h
4.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
segment.h
132 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
serial.h
1.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
sfp-machine.h
2.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
shmparam.h
191 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
signal.h
627 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
smp.h
1.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
socket.h
310 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
special_insns.h
925 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
spinlock.h
2.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
spinlock_types.h
413 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
string.h
2.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
switch_to.h
406 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
syscall.h
235 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
termios.h
2.98 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
thread_info.h
3.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
timex.h
827 bytes
11/01/2022 04:52:05 PM
rw-r--r--
📄
tlb.h
473 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
tlbflush.h
3.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
topology.h
957 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
types.h
143 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
uaccess.h
9.56 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
ucontext.h
348 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
unaligned.h
340 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
unistd.h
494 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
user.h
2.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
vga.h
2 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
word-at-a-time.h
1.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
wrperfmon.h
2.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
xchg.h
5.74 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
xor.h
21.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
Editing: mmu_context.h
Close
/* SPDX-License-Identifier: GPL-2.0 */ #ifndef __ALPHA_MMU_CONTEXT_H #define __ALPHA_MMU_CONTEXT_H /* * get a new mmu context.. * * Copyright (C) 1996, Linus Torvalds */ #include <linux/mm_types.h> #include <linux/sched.h> #include <asm/machvec.h> #include <asm/compiler.h> #include <asm-generic/mm_hooks.h> /* * Force a context reload. This is needed when we change the page * table pointer or when we update the ASN of the current process. */ /* Don't get into trouble with dueling __EXTERN_INLINEs. */ #ifndef __EXTERN_INLINE #include <asm/io.h> #endif static inline unsigned long __reload_thread(struct pcb_struct *pcb) { register unsigned long a0 __asm__("$16"); register unsigned long v0 __asm__("$0"); a0 = virt_to_phys(pcb); __asm__ __volatile__( "call_pal %2 #__reload_thread" : "=r"(v0), "=r"(a0) : "i"(PAL_swpctx), "r"(a0) : "$1", "$22", "$23", "$24", "$25"); return v0; } /* * The maximum ASN's the processor supports. On the EV4 this is 63 * but the PAL-code doesn't actually use this information. On the * EV5 this is 127, and EV6 has 255. * * On the EV4, the ASNs are more-or-less useless anyway, as they are * only used as an icache tag, not for TB entries. On the EV5 and EV6, * ASN's also validate the TB entries, and thus make a lot more sense. * * The EV4 ASN's don't even match the architecture manual, ugh. And * I quote: "If a processor implements address space numbers (ASNs), * and the old PTE has the Address Space Match (ASM) bit clear (ASNs * in use) and the Valid bit set, then entries can also effectively be * made coherent by assigning a new, unused ASN to the currently * running process and not reusing the previous ASN before calling the * appropriate PALcode routine to invalidate the translation buffer (TB)". * * In short, the EV4 has a "kind of" ASN capability, but it doesn't actually * work correctly and can thus not be used (explaining the lack of PAL-code * support). */ #define EV4_MAX_ASN 63 #define EV5_MAX_ASN 127 #define EV6_MAX_ASN 255 #ifdef CONFIG_ALPHA_GENERIC # define MAX_ASN (alpha_mv.max_asn) #else # ifdef CONFIG_ALPHA_EV4 # define MAX_ASN EV4_MAX_ASN # elif defined(CONFIG_ALPHA_EV5) # define MAX_ASN EV5_MAX_ASN # else # define MAX_ASN EV6_MAX_ASN # endif #endif /* * cpu_last_asn(processor): * 63 0 * +-------------+----------------+--------------+ * | asn version | this processor | hardware asn | * +-------------+----------------+--------------+ */ #include <asm/smp.h> #ifdef CONFIG_SMP #define cpu_last_asn(cpuid) (cpu_data[cpuid].last_asn) #else extern unsigned long last_asn; #define cpu_last_asn(cpuid) last_asn #endif /* CONFIG_SMP */ #define WIDTH_HARDWARE_ASN 8 #define ASN_FIRST_VERSION (1UL << WIDTH_HARDWARE_ASN) #define HARDWARE_ASN_MASK ((1UL << WIDTH_HARDWARE_ASN) - 1) /* * NOTE! The way this is set up, the high bits of the "asn_cache" (and * the "mm->context") are the ASN _version_ code. A version of 0 is * always considered invalid, so to invalidate another process you only * need to do "p->mm->context = 0". * * If we need more ASN's than the processor has, we invalidate the old * user TLB's (tbiap()) and start a new ASN version. That will automatically * force a new asn for any other processes the next time they want to * run. */ #ifndef __EXTERN_INLINE #define __EXTERN_INLINE extern inline #define __MMU_EXTERN_INLINE #endif extern inline unsigned long __get_new_mm_context(struct mm_struct *mm, long cpu) { unsigned long asn = cpu_last_asn(cpu); unsigned long next = asn + 1; if ((asn & HARDWARE_ASN_MASK) >= MAX_ASN) { tbiap(); imb(); next = (asn & ~HARDWARE_ASN_MASK) + ASN_FIRST_VERSION; } cpu_last_asn(cpu) = next; return next; } __EXTERN_INLINE void ev5_switch_mm(struct mm_struct *prev_mm, struct mm_struct *next_mm, struct task_struct *next) { /* Check if our ASN is of an older version, and thus invalid. */ unsigned long asn; unsigned long mmc; long cpu = smp_processor_id(); #ifdef CONFIG_SMP cpu_data[cpu].asn_lock = 1; barrier(); #endif asn = cpu_last_asn(cpu); mmc = next_mm->context[cpu]; if ((mmc ^ asn) & ~HARDWARE_ASN_MASK) { mmc = __get_new_mm_context(next_mm, cpu); next_mm->context[cpu] = mmc; } #ifdef CONFIG_SMP else cpu_data[cpu].need_new_asn = 1; #endif /* Always update the PCB ASN. Another thread may have allocated a new mm->context (via flush_tlb_mm) without the ASN serial number wrapping. We have no way to detect when this is needed. */ task_thread_info(next)->pcb.asn = mmc & HARDWARE_ASN_MASK; } __EXTERN_INLINE void ev4_switch_mm(struct mm_struct *prev_mm, struct mm_struct *next_mm, struct task_struct *next) { /* As described, ASN's are broken for TLB usage. But we can optimize for switching between threads -- if the mm is unchanged from current we needn't flush. */ /* ??? May not be needed because EV4 PALcode recognizes that ASN's are broken and does a tbiap itself on swpctx, under the "Must set ASN or flush" rule. At least this is true for a 1992 SRM, reports Joseph Martin (jmartin@hlo.dec.com). I'm going to leave this here anyway, just to Be Sure. -- r~ */ if (prev_mm != next_mm) tbiap(); /* Do continue to allocate ASNs, because we can still use them to avoid flushing the icache. */ ev5_switch_mm(prev_mm, next_mm, next); } extern void __load_new_mm_context(struct mm_struct *); #ifdef CONFIG_SMP #define check_mmu_context() \ do { \ int cpu = smp_processor_id(); \ cpu_data[cpu].asn_lock = 0; \ barrier(); \ if (cpu_data[cpu].need_new_asn) { \ struct mm_struct * mm = current->active_mm; \ cpu_data[cpu].need_new_asn = 0; \ if (!mm->context[cpu]) \ __load_new_mm_context(mm); \ } \ } while(0) #else #define check_mmu_context() do { } while(0) #endif __EXTERN_INLINE void ev5_activate_mm(struct mm_struct *prev_mm, struct mm_struct *next_mm) { __load_new_mm_context(next_mm); } __EXTERN_INLINE void ev4_activate_mm(struct mm_struct *prev_mm, struct mm_struct *next_mm) { __load_new_mm_context(next_mm); tbiap(); } #define deactivate_mm(tsk,mm) do { } while (0) #ifdef CONFIG_ALPHA_GENERIC # define switch_mm(a,b,c) alpha_mv.mv_switch_mm((a),(b),(c)) # define activate_mm(x,y) alpha_mv.mv_activate_mm((x),(y)) #else # ifdef CONFIG_ALPHA_EV4 # define switch_mm(a,b,c) ev4_switch_mm((a),(b),(c)) # define activate_mm(x,y) ev4_activate_mm((x),(y)) # else # define switch_mm(a,b,c) ev5_switch_mm((a),(b),(c)) # define activate_mm(x,y) ev5_activate_mm((x),(y)) # endif #endif static inline int init_new_context(struct task_struct *tsk, struct mm_struct *mm) { int i; for_each_online_cpu(i) mm->context[i] = 0; if (tsk != current) task_thread_info(tsk)->pcb.ptbr = ((unsigned long)mm->pgd - IDENT_ADDR) >> PAGE_SHIFT; return 0; } extern inline void destroy_context(struct mm_struct *mm) { /* Nothing to do. */ } static inline void enter_lazy_tlb(struct mm_struct *mm, struct task_struct *tsk) { task_thread_info(tsk)->pcb.ptbr = ((unsigned long)mm->pgd - IDENT_ADDR) >> PAGE_SHIFT; } #ifdef __MMU_EXTERN_INLINE #undef __EXTERN_INLINE #undef __MMU_EXTERN_INLINE #endif #endif /* __ALPHA_MMU_CONTEXT_H */