1*4882a593Smuzhiyun/* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun/* 3*4882a593Smuzhiyun * linux/arch/arm/mm/proc-arm7tdmi.S: utility functions for ARM7TDMI 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2003-2006 Hyok S. Choi <hyok.choi@samsung.com> 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun#include <linux/linkage.h> 8*4882a593Smuzhiyun#include <linux/init.h> 9*4882a593Smuzhiyun#include <linux/pgtable.h> 10*4882a593Smuzhiyun#include <asm/assembler.h> 11*4882a593Smuzhiyun#include <asm/asm-offsets.h> 12*4882a593Smuzhiyun#include <asm/hwcap.h> 13*4882a593Smuzhiyun#include <asm/pgtable-hwdef.h> 14*4882a593Smuzhiyun#include <asm/ptrace.h> 15*4882a593Smuzhiyun 16*4882a593Smuzhiyun#include "proc-macros.S" 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun .text 19*4882a593Smuzhiyun/* 20*4882a593Smuzhiyun * cpu_arm7tdmi_proc_init() 21*4882a593Smuzhiyun * cpu_arm7tdmi_do_idle() 22*4882a593Smuzhiyun * cpu_arm7tdmi_dcache_clean_area() 23*4882a593Smuzhiyun * cpu_arm7tdmi_switch_mm() 24*4882a593Smuzhiyun * 25*4882a593Smuzhiyun * These are not required. 26*4882a593Smuzhiyun */ 27*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_proc_init) 28*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_do_idle) 29*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_dcache_clean_area) 30*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_switch_mm) 31*4882a593Smuzhiyun ret lr 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun/* 34*4882a593Smuzhiyun * cpu_arm7tdmi_proc_fin() 35*4882a593Smuzhiyun */ 36*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_proc_fin) 37*4882a593Smuzhiyun ret lr 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun/* 40*4882a593Smuzhiyun * Function: cpu_arm7tdmi_reset(loc) 41*4882a593Smuzhiyun * Params : loc(r0) address to jump to 42*4882a593Smuzhiyun * Purpose : Sets up everything for a reset and jump to the location for soft reset. 43*4882a593Smuzhiyun */ 44*4882a593Smuzhiyun .pushsection .idmap.text, "ax" 45*4882a593SmuzhiyunENTRY(cpu_arm7tdmi_reset) 46*4882a593Smuzhiyun ret r0 47*4882a593SmuzhiyunENDPROC(cpu_arm7tdmi_reset) 48*4882a593Smuzhiyun .popsection 49*4882a593Smuzhiyun 50*4882a593Smuzhiyun .type __arm7tdmi_setup, #function 51*4882a593Smuzhiyun__arm7tdmi_setup: 52*4882a593Smuzhiyun ret lr 53*4882a593Smuzhiyun .size __arm7tdmi_setup, . - __arm7tdmi_setup 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun __INITDATA 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun @ define struct processor (see <asm/proc-fns.h> and proc-macros.S) 58*4882a593Smuzhiyun define_processor_functions arm7tdmi, dabort=v4t_late_abort, pabort=legacy_pabort, nommu=1 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun .section ".rodata" 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun string cpu_arch_name, "armv4t" 63*4882a593Smuzhiyun string cpu_elf_name, "v4" 64*4882a593Smuzhiyun string cpu_arm7tdmi_name, "ARM7TDMI" 65*4882a593Smuzhiyun string cpu_triscenda7_name, "Triscend-A7x" 66*4882a593Smuzhiyun string cpu_at91_name, "Atmel-AT91M40xxx" 67*4882a593Smuzhiyun string cpu_s3c3410_name, "Samsung-S3C3410" 68*4882a593Smuzhiyun string cpu_s3c44b0x_name, "Samsung-S3C44B0x" 69*4882a593Smuzhiyun string cpu_s3c4510b_name, "Samsung-S3C4510B" 70*4882a593Smuzhiyun string cpu_s3c4530_name, "Samsung-S3C4530" 71*4882a593Smuzhiyun string cpu_netarm_name, "NETARM" 72*4882a593Smuzhiyun 73*4882a593Smuzhiyun .align 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun .section ".proc.info.init", "a" 76*4882a593Smuzhiyun 77*4882a593Smuzhiyun.macro arm7tdmi_proc_info name:req, cpu_val:req, cpu_mask:req, cpu_name:req, \ 78*4882a593Smuzhiyun extra_hwcaps=0 79*4882a593Smuzhiyun .type __\name\()_proc_info, #object 80*4882a593Smuzhiyun__\name\()_proc_info: 81*4882a593Smuzhiyun .long \cpu_val 82*4882a593Smuzhiyun .long \cpu_mask 83*4882a593Smuzhiyun .long 0 84*4882a593Smuzhiyun .long 0 85*4882a593Smuzhiyun initfn __arm7tdmi_setup, __\name\()_proc_info 86*4882a593Smuzhiyun .long cpu_arch_name 87*4882a593Smuzhiyun .long cpu_elf_name 88*4882a593Smuzhiyun .long HWCAP_SWP | HWCAP_26BIT | ( \extra_hwcaps ) 89*4882a593Smuzhiyun .long \cpu_name 90*4882a593Smuzhiyun .long arm7tdmi_processor_functions 91*4882a593Smuzhiyun .long 0 92*4882a593Smuzhiyun .long 0 93*4882a593Smuzhiyun .long v4_cache_fns 94*4882a593Smuzhiyun .size __\name\()_proc_info, . - __\name\()_proc_info 95*4882a593Smuzhiyun.endm 96*4882a593Smuzhiyun 97*4882a593Smuzhiyun arm7tdmi_proc_info arm7tdmi, 0x41007700, 0xfff8ff00, \ 98*4882a593Smuzhiyun cpu_arm7tdmi_name 99*4882a593Smuzhiyun arm7tdmi_proc_info triscenda7, 0x0001d2ff, 0x0001ffff, \ 100*4882a593Smuzhiyun cpu_triscenda7_name, extra_hwcaps=HWCAP_THUMB 101*4882a593Smuzhiyun arm7tdmi_proc_info at91, 0x14000040, 0xfff000e0, \ 102*4882a593Smuzhiyun cpu_at91_name, extra_hwcaps=HWCAP_THUMB 103*4882a593Smuzhiyun arm7tdmi_proc_info s3c4510b, 0x36365000, 0xfffff000, \ 104*4882a593Smuzhiyun cpu_s3c4510b_name, extra_hwcaps=HWCAP_THUMB 105*4882a593Smuzhiyun arm7tdmi_proc_info s3c4530, 0x4c000000, 0xfff000e0, \ 106*4882a593Smuzhiyun cpu_s3c4530_name, extra_hwcaps=HWCAP_THUMB 107*4882a593Smuzhiyun arm7tdmi_proc_info s3c3410, 0x34100000, 0xffff0000, \ 108*4882a593Smuzhiyun cpu_s3c3410_name, extra_hwcaps=HWCAP_THUMB 109*4882a593Smuzhiyun arm7tdmi_proc_info s3c44b0x, 0x44b00000, 0xffff0000, \ 110*4882a593Smuzhiyun cpu_s3c44b0x_name, extra_hwcaps=HWCAP_THUMB 111