OXIESEC PANEL
- Current Dir:
/
/
usr
/
src
/
linux-headers-4.15.0-213
/
arch
/
mips
/
include
/
asm
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
05/09/2024 07:14:13 AM
rwxr-xr-x
📄
Kbuild
577 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
abi.h
853 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
addrspace.h
4.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
amon.h
409 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
arch_hweight.h
792 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
asm-eva.h
6.82 KB
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
197 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
asm.h
8.47 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
asmmacro-32.h
2.47 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
asmmacro-64.h
1.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
asmmacro.h
14.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
atomic.h
19.73 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
barrier.h
8.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
bcache.h
2.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
bitops.h
15.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
bitrev.h
608 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
bmips-spaces.h
268 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
bmips.h
3.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
bootinfo.h
5.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
branch.h
2.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
break.h
787 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
bug.h
759 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
bugs.h
944 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cache.h
546 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cacheflush.h
4.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
cacheops.h
3.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
cdmm.h
3.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
cevt-r4k.h
823 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
checksum.h
6.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
clock.h
997 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
clocksource.h
884 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cmp.h
492 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
cmpxchg.h
5.28 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
compat-signal.h
640 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
compat.h
6.66 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
compiler.h
2.96 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
cop2.h
1.77 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
cpu-features.h
19.46 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
cpu-info.h
5.84 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
cpu-type.h
4.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
cpu.h
15.54 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
cpufeature.h
717 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
debug.h
654 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📁
dec
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
delay.h
841 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
device.h
347 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
div64.h
2.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
dma-coherence.h
813 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
dma-mapping.h
981 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
dma.h
9.92 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ds1287.h
1019 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
dsemul.h
3.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
dsp.h
1.91 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
edac.h
819 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
elf.h
15.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
emma
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
errno.h
429 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
eva.h
796 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
exec.h
579 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
extable.h
241 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
fb.h
372 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
fixmap.h
2.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
floppy.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
fpregdef.h
2.66 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
fpu.h
5.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
fpu_emulator.h
5.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ftrace.h
2.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
futex.h
4.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
fw
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
gio_device.h
1.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
gt64120.h
19.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
hardirq.h
544 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
hazards.h
8.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
highmem.h
1.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
hpet.h
1.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
hugetlb.h
2.76 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
hw_irq.h
475 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
i8259.h
2.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ide.h
330 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
idle.h
689 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
inst.h
2.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
io.h
18.44 KB
06/16/2023 05:32:39 PM
rw-r--r--
📁
ip32
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
irq.h
2.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
irq_cpu.h
708 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
irq_gt641xx.h
2.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
irq_regs.h
744 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
irqflags.h
4.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
isa-rev.h
556 bytes
06/16/2023 05:32:39 PM
rw-r--r--
📄
isadep.h
603 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
jazz.h
8 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
jazzdma.h
2.97 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
jump_label.h
1.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
kdebug.h
303 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
kexec.h
1.53 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
kgdb.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
kmap_types.h
221 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
kprobes.h
2.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
kvm_host.h
37.88 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
kvm_para.h
2.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
lasat
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
linkage.h
306 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
llsc.h
623 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
local.h
4.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
m48t37.h
732 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
maar.h
4.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
mach-ar7
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ath25
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ath79
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-au1x00
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-bcm47xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-bcm63xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-bmips
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-cavium-octeon
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-cobalt
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-db1x00
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-dec
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-emma2rh
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-generic
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ip22
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ip27
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ip28
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ip32
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-jazz
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-jz4740
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-lantiq
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-lasat
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-loongson32
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-loongson64
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-malta
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-netlogic
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-paravirt
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-pic32
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-pistachio
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-pmcs-msp71xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-pnx833x
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-ralink
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-rc32434
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-rm
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-sibyte
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-tx39xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-tx49xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-vr41xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📁
mach-xilfpga
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
machine.h
2.93 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
mc146818-time.h
3.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mc146818rtc.h
450 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📁
mips-boards
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
mips-cm.h
15.86 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
mips-cpc.h
5.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mips-cps.h
6.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mips-gic.h
12.3 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
mips-r2-to-r6-emul.h
2.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mips_machine.h
1.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mips_mt.h
707 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
mipsmtregs.h
10.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mipsprom.h
2.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
mipsregs.h
88.1 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
mmu.h
550 bytes
06/16/2023 05:32:39 PM
rw-r--r--
📄
mmu_context.h
5.41 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
mmzone.h
561 bytes
06/16/2023 05:32:39 PM
rw-r--r--
📄
module.h
4.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
msa.h
8.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
msc01_ic.h
6.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
netlogic
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
nile4.h
10.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
octeon
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
paccess.h
3.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
page.h
7.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
pci
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
pci.h
4.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
perf_event.h
482 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
pgalloc.h
3.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pgtable-32.h
7.31 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
pgtable-64.h
10.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
pgtable-bits.h
7.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pgtable.h
17.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pm-cps.h
1.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pm.h
3.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pmon.h
1.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
prefetch.h
2.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
processor.h
11.71 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
prom.h
845 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
ptrace.h
5.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
r4k-timer.h
604 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
r4kcache.h
26.34 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
reboot.h
440 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
reg.h
26 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
regdef.h
2.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
rtlx.h
2.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
seccomp.h
800 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
serial.h
607 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
setup.h
884 bytes
06/16/2023 05:32:39 PM
rw-r--r--
📁
sgi
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
sgialib.h
2.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
sgiarcs.h
15.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
shmparam.h
352 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📁
sibyte
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
sigcontext.h
1.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
signal.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
sim.h
2.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
smp-cps.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
smp-ops.h
2.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
smp.h
3.31 KB
06/16/2023 05:32:39 PM
rw-r--r--
📁
sn
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
sni.h
7.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
socket.h
1.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
sparsemem.h
486 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
spinlock.h
459 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
spinlock_types.h
188 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
spram.h
262 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
stackframe.h
10.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
stackprotector.h
1.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
stacktrace.h
2.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
string.h
2.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
switch_to.h
4.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
syscall.h
3.57 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
termios.h
2.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
thread_info.h
6.63 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
time.h
2.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
timex.h
2.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
tlb.h
1.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
tlbdebug.h
403 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
tlbex.h
788 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
tlbflush.h
1.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
tlbmisc.h
320 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
topology.h
619 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
traps.h
1.25 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
txx9
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
txx9irq.h
743 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
txx9pio.h
592 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
txx9tmr.h
1.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
types.h
487 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
uaccess.h
22.2 KB
06/16/2023 05:32:39 PM
rw-r--r--
📄
uasm.h
9.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
unistd.h
1.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
uprobes.h
1.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
vdso.h
3.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
vga.h
1.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
vpe.h
2.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
📁
vr41xx
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
war.h
7.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
watch.h
827 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
wbflush.h
694 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📁
xtalk
-
05/09/2024 07:14:16 AM
rwxr-xr-x
📄
yamon-dt.h
1.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
Editing: mipsmtregs.h
Close
/* SPDX-License-Identifier: GPL-2.0 */ /* * MT regs definitions, follows on from mipsregs.h * Copyright (C) 2004 - 2005 MIPS Technologies, Inc. All rights reserved. * Elizabeth Clarke et. al. * */ #ifndef _ASM_MIPSMTREGS_H #define _ASM_MIPSMTREGS_H #include <asm/mipsregs.h> #include <asm/war.h> #ifndef __ASSEMBLY__ /* * C macros */ #define read_c0_mvpcontrol() __read_32bit_c0_register($0, 1) #define write_c0_mvpcontrol(val) __write_32bit_c0_register($0, 1, val) #define read_c0_mvpconf0() __read_32bit_c0_register($0, 2) #define read_c0_mvpconf1() __read_32bit_c0_register($0, 3) #define read_c0_vpecontrol() __read_32bit_c0_register($1, 1) #define write_c0_vpecontrol(val) __write_32bit_c0_register($1, 1, val) #define read_c0_vpeconf0() __read_32bit_c0_register($1, 2) #define write_c0_vpeconf0(val) __write_32bit_c0_register($1, 2, val) #define read_c0_vpeconf1() __read_32bit_c0_register($1, 3) #define write_c0_vpeconf1(val) __write_32bit_c0_register($1, 3, val) #define read_c0_tcstatus() __read_32bit_c0_register($2, 1) #define write_c0_tcstatus(val) __write_32bit_c0_register($2, 1, val) #define read_c0_tcbind() __read_32bit_c0_register($2, 2) #define write_c0_tchalt(val) __write_32bit_c0_register($2, 4, val) #define read_c0_tccontext() __read_32bit_c0_register($2, 5) #define write_c0_tccontext(val) __write_32bit_c0_register($2, 5, val) #else /* Assembly */ /* * Macros for use in assembly language code */ #define CP0_MVPCONTROL $0, 1 #define CP0_MVPCONF0 $0, 2 #define CP0_MVPCONF1 $0, 3 #define CP0_VPECONTROL $1, 1 #define CP0_VPECONF0 $1, 2 #define CP0_VPECONF1 $1, 3 #define CP0_YQMASK $1, 4 #define CP0_VPESCHEDULE $1, 5 #define CP0_VPESCHEFBK $1, 6 #define CP0_TCSTATUS $2, 1 #define CP0_TCBIND $2, 2 #define CP0_TCRESTART $2, 3 #define CP0_TCHALT $2, 4 #define CP0_TCCONTEXT $2, 5 #define CP0_TCSCHEDULE $2, 6 #define CP0_TCSCHEFBK $2, 7 #define CP0_SRSCONF0 $6, 1 #define CP0_SRSCONF1 $6, 2 #define CP0_SRSCONF2 $6, 3 #define CP0_SRSCONF3 $6, 4 #define CP0_SRSCONF4 $6, 5 #endif /* MVPControl fields */ #define MVPCONTROL_EVP (_ULCAST_(1)) #define MVPCONTROL_VPC_SHIFT 1 #define MVPCONTROL_VPC (_ULCAST_(1) << MVPCONTROL_VPC_SHIFT) #define MVPCONTROL_STLB_SHIFT 2 #define MVPCONTROL_STLB (_ULCAST_(1) << MVPCONTROL_STLB_SHIFT) /* MVPConf0 fields */ #define MVPCONF0_PTC_SHIFT 0 #define MVPCONF0_PTC ( _ULCAST_(0xff)) #define MVPCONF0_PVPE_SHIFT 10 #define MVPCONF0_PVPE ( _ULCAST_(0xf) << MVPCONF0_PVPE_SHIFT) #define MVPCONF0_TCA_SHIFT 15 #define MVPCONF0_TCA ( _ULCAST_(1) << MVPCONF0_TCA_SHIFT) #define MVPCONF0_PTLBE_SHIFT 16 #define MVPCONF0_PTLBE (_ULCAST_(0x3ff) << MVPCONF0_PTLBE_SHIFT) #define MVPCONF0_TLBS_SHIFT 29 #define MVPCONF0_TLBS (_ULCAST_(1) << MVPCONF0_TLBS_SHIFT) #define MVPCONF0_M_SHIFT 31 #define MVPCONF0_M (_ULCAST_(0x1) << MVPCONF0_M_SHIFT) /* config3 fields */ #define CONFIG3_MT_SHIFT 2 #define CONFIG3_MT (_ULCAST_(1) << CONFIG3_MT_SHIFT) /* VPEControl fields (per VPE) */ #define VPECONTROL_TARGTC (_ULCAST_(0xff)) #define VPECONTROL_TE_SHIFT 15 #define VPECONTROL_TE (_ULCAST_(1) << VPECONTROL_TE_SHIFT) #define VPECONTROL_EXCPT_SHIFT 16 #define VPECONTROL_EXCPT (_ULCAST_(0x7) << VPECONTROL_EXCPT_SHIFT) /* Thread Exception Codes for EXCPT field */ #define THREX_TU 0 #define THREX_TO 1 #define THREX_IYQ 2 #define THREX_GSX 3 #define THREX_YSCH 4 #define THREX_GSSCH 5 #define VPECONTROL_GSI_SHIFT 20 #define VPECONTROL_GSI (_ULCAST_(1) << VPECONTROL_GSI_SHIFT) #define VPECONTROL_YSI_SHIFT 21 #define VPECONTROL_YSI (_ULCAST_(1) << VPECONTROL_YSI_SHIFT) /* VPEConf0 fields (per VPE) */ #define VPECONF0_VPA_SHIFT 0 #define VPECONF0_VPA (_ULCAST_(1) << VPECONF0_VPA_SHIFT) #define VPECONF0_MVP_SHIFT 1 #define VPECONF0_MVP (_ULCAST_(1) << VPECONF0_MVP_SHIFT) #define VPECONF0_XTC_SHIFT 21 #define VPECONF0_XTC (_ULCAST_(0xff) << VPECONF0_XTC_SHIFT) /* VPEConf1 fields (per VPE) */ #define VPECONF1_NCP1_SHIFT 0 #define VPECONF1_NCP1 (_ULCAST_(0xff) << VPECONF1_NCP1_SHIFT) #define VPECONF1_NCP2_SHIFT 10 #define VPECONF1_NCP2 (_ULCAST_(0xff) << VPECONF1_NCP2_SHIFT) #define VPECONF1_NCX_SHIFT 20 #define VPECONF1_NCX (_ULCAST_(0xff) << VPECONF1_NCX_SHIFT) /* TCStatus fields (per TC) */ #define TCSTATUS_TASID (_ULCAST_(0xff)) #define TCSTATUS_IXMT_SHIFT 10 #define TCSTATUS_IXMT (_ULCAST_(1) << TCSTATUS_IXMT_SHIFT) #define TCSTATUS_TKSU_SHIFT 11 #define TCSTATUS_TKSU (_ULCAST_(3) << TCSTATUS_TKSU_SHIFT) #define TCSTATUS_A_SHIFT 13 #define TCSTATUS_A (_ULCAST_(1) << TCSTATUS_A_SHIFT) #define TCSTATUS_DA_SHIFT 15 #define TCSTATUS_DA (_ULCAST_(1) << TCSTATUS_DA_SHIFT) #define TCSTATUS_DT_SHIFT 20 #define TCSTATUS_DT (_ULCAST_(1) << TCSTATUS_DT_SHIFT) #define TCSTATUS_TDS_SHIFT 21 #define TCSTATUS_TDS (_ULCAST_(1) << TCSTATUS_TDS_SHIFT) #define TCSTATUS_TSST_SHIFT 22 #define TCSTATUS_TSST (_ULCAST_(1) << TCSTATUS_TSST_SHIFT) #define TCSTATUS_RNST_SHIFT 23 #define TCSTATUS_RNST (_ULCAST_(3) << TCSTATUS_RNST_SHIFT) /* Codes for RNST */ #define TC_RUNNING 0 #define TC_WAITING 1 #define TC_YIELDING 2 #define TC_GATED 3 #define TCSTATUS_TMX_SHIFT 27 #define TCSTATUS_TMX (_ULCAST_(1) << TCSTATUS_TMX_SHIFT) /* TCStatus TCU bits can use same definitions/offsets as CU bits in Status */ /* TCBind */ #define TCBIND_CURVPE_SHIFT 0 #define TCBIND_CURVPE (_ULCAST_(0xf)) #define TCBIND_CURTC_SHIFT 21 #define TCBIND_CURTC (_ULCAST_(0xff) << TCBIND_CURTC_SHIFT) /* TCHalt */ #define TCHALT_H (_ULCAST_(1)) #ifndef __ASSEMBLY__ static inline unsigned core_nvpes(void) { unsigned conf0; if (!cpu_has_mipsmt) return 1; conf0 = read_c0_mvpconf0(); return ((conf0 & MVPCONF0_PVPE) >> MVPCONF0_PVPE_SHIFT) + 1; } static inline unsigned int dvpe(void) { int res = 0; __asm__ __volatile__( " .set push \n" " .set noreorder \n" " .set noat \n" " .set mips32r2 \n" " .word 0x41610001 # dvpe $1 \n" " move %0, $1 \n" " ehb \n" " .set pop \n" : "=r" (res)); instruction_hazard(); return res; } static inline void __raw_evpe(void) { __asm__ __volatile__( " .set push \n" " .set noreorder \n" " .set noat \n" " .set mips32r2 \n" " .word 0x41600021 # evpe \n" " ehb \n" " .set pop \n"); } /* Enable virtual processor execution if previous suggested it should be. EVPE_ENABLE to force */ #define EVPE_ENABLE MVPCONTROL_EVP static inline void evpe(int previous) { if ((previous & MVPCONTROL_EVP)) __raw_evpe(); } static inline unsigned int dmt(void) { int res; __asm__ __volatile__( " .set push \n" " .set mips32r2 \n" " .set noat \n" " .word 0x41610BC1 # dmt $1 \n" " ehb \n" " move %0, $1 \n" " .set pop \n" : "=r" (res)); instruction_hazard(); return res; } static inline void __raw_emt(void) { __asm__ __volatile__( " .set noreorder \n" " .set mips32r2 \n" " .word 0x41600be1 # emt \n" " ehb \n" " .set mips0 \n" " .set reorder"); } /* enable multi-threaded execution if previous suggested it should be. EMT_ENABLE to force */ #define EMT_ENABLE VPECONTROL_TE static inline void emt(int previous) { if ((previous & EMT_ENABLE)) __raw_emt(); } static inline void ehb(void) { __asm__ __volatile__( " .set mips32r2 \n" " ehb \n" " .set mips0 \n"); } #define mftc0(rt,sel) \ ({ \ unsigned long __res; \ \ __asm__ __volatile__( \ " .set push \n" \ " .set mips32r2 \n" \ " .set noat \n" \ " # mftc0 $1, $" #rt ", " #sel " \n" \ " .word 0x41000800 | (" #rt " << 16) | " #sel " \n" \ " move %0, $1 \n" \ " .set pop \n" \ : "=r" (__res)); \ \ __res; \ }) #define mftgpr(rt) \ ({ \ unsigned long __res; \ \ __asm__ __volatile__( \ " .set push \n" \ " .set noat \n" \ " .set mips32r2 \n" \ " # mftgpr $1," #rt " \n" \ " .word 0x41000820 | (" #rt " << 16) \n" \ " move %0, $1 \n" \ " .set pop \n" \ : "=r" (__res)); \ \ __res; \ }) #define mftr(rt, u, sel) \ ({ \ unsigned long __res; \ \ __asm__ __volatile__( \ " mftr %0, " #rt ", " #u ", " #sel " \n" \ : "=r" (__res)); \ \ __res; \ }) #define mttgpr(rd,v) \ do { \ __asm__ __volatile__( \ " .set push \n" \ " .set mips32r2 \n" \ " .set noat \n" \ " move $1, %0 \n" \ " # mttgpr $1, " #rd " \n" \ " .word 0x41810020 | (" #rd " << 11) \n" \ " .set pop \n" \ : : "r" (v)); \ } while (0) #define mttc0(rd, sel, v) \ ({ \ __asm__ __volatile__( \ " .set push \n" \ " .set mips32r2 \n" \ " .set noat \n" \ " move $1, %0 \n" \ " # mttc0 %0," #rd ", " #sel " \n" \ " .word 0x41810000 | (" #rd " << 11) | " #sel " \n" \ " .set pop \n" \ : \ : "r" (v)); \ }) #define mttr(rd, u, sel, v) \ ({ \ __asm__ __volatile__( \ "mttr %0," #rd ", " #u ", " #sel \ : : "r" (v)); \ }) #define settc(tc) \ do { \ write_c0_vpecontrol((read_c0_vpecontrol()&~VPECONTROL_TARGTC) | (tc)); \ ehb(); \ } while (0) /* you *must* set the target tc (settc) before trying to use these */ #define read_vpe_c0_vpecontrol() mftc0(1, 1) #define write_vpe_c0_vpecontrol(val) mttc0(1, 1, val) #define read_vpe_c0_vpeconf0() mftc0(1, 2) #define write_vpe_c0_vpeconf0(val) mttc0(1, 2, val) #define read_vpe_c0_vpeconf1() mftc0(1, 3) #define write_vpe_c0_vpeconf1(val) mttc0(1, 3, val) #define read_vpe_c0_count() mftc0(9, 0) #define write_vpe_c0_count(val) mttc0(9, 0, val) #define read_vpe_c0_status() mftc0(12, 0) #define write_vpe_c0_status(val) mttc0(12, 0, val) #define read_vpe_c0_cause() mftc0(13, 0) #define write_vpe_c0_cause(val) mttc0(13, 0, val) #define read_vpe_c0_config() mftc0(16, 0) #define write_vpe_c0_config(val) mttc0(16, 0, val) #define read_vpe_c0_config1() mftc0(16, 1) #define write_vpe_c0_config1(val) mttc0(16, 1, val) #define read_vpe_c0_config7() mftc0(16, 7) #define write_vpe_c0_config7(val) mttc0(16, 7, val) #define read_vpe_c0_ebase() mftc0(15, 1) #define write_vpe_c0_ebase(val) mttc0(15, 1, val) #define write_vpe_c0_compare(val) mttc0(11, 0, val) #define read_vpe_c0_badvaddr() mftc0(8, 0) #define read_vpe_c0_epc() mftc0(14, 0) #define write_vpe_c0_epc(val) mttc0(14, 0, val) /* TC */ #define read_tc_c0_tcstatus() mftc0(2, 1) #define write_tc_c0_tcstatus(val) mttc0(2, 1, val) #define read_tc_c0_tcbind() mftc0(2, 2) #define write_tc_c0_tcbind(val) mttc0(2, 2, val) #define read_tc_c0_tcrestart() mftc0(2, 3) #define write_tc_c0_tcrestart(val) mttc0(2, 3, val) #define read_tc_c0_tchalt() mftc0(2, 4) #define write_tc_c0_tchalt(val) mttc0(2, 4, val) #define read_tc_c0_tccontext() mftc0(2, 5) #define write_tc_c0_tccontext(val) mttc0(2, 5, val) /* GPR */ #define read_tc_gpr_sp() mftgpr(29) #define write_tc_gpr_sp(val) mttgpr(29, val) #define read_tc_gpr_gp() mftgpr(28) #define write_tc_gpr_gp(val) mttgpr(28, val) __BUILD_SET_C0(mvpcontrol) #endif /* Not __ASSEMBLY__ */ #endif