Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/acorn32/stand Modernize acorn32 boot code to work d...



details:   https://anonhg.NetBSD.org/src/rev/04e3d18a7964
branches:  trunk
changeset: 1018538:04e3d18a7964
user:      joerg <joerg%NetBSD.org@localhost>
date:      Sat Feb 06 21:45:38 2021 +0000

description:
Modernize acorn32 boot code to work directly with LLVM's assembler.

diffstat:

 sys/arch/acorn32/stand/boot32/Makefile |   4 +---
 sys/arch/acorn32/stand/boot32/start.S  |  34 +++++++++++++++++-----------------
 sys/arch/acorn32/stand/nbfs/Makefile   |   4 +---
 sys/arch/acorn32/stand/nbfs/rmheader.S |  14 ++++++++------
 4 files changed, 27 insertions(+), 29 deletions(-)

diffs (181 lines):

diff -r c33658de6ba6 -r 04e3d18a7964 sys/arch/acorn32/stand/boot32/Makefile
--- a/sys/arch/acorn32/stand/boot32/Makefile    Sat Feb 06 21:40:14 2021 +0000
+++ b/sys/arch/acorn32/stand/boot32/Makefile    Sat Feb 06 21:45:38 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.6 2019/08/02 12:06:20 joerg Exp $
+#      $NetBSD: Makefile,v 1.7 2021/02/06 21:45:38 joerg Exp $
 
 PROG=          boot32
 PROGSOURCE=    rmheader.S rmvers.c srt0.S boot32.c start.S
@@ -17,6 +17,4 @@
 
 CLEANFILES+=   rmvers.c
 
-AFLAGS.start.S= ${${ACTIVE_CC} == "clang":?-no-integrated-as:}
-
 .include "../Makefile.buildboot"
diff -r c33658de6ba6 -r 04e3d18a7964 sys/arch/acorn32/stand/boot32/start.S
--- a/sys/arch/acorn32/stand/boot32/start.S     Sat Feb 06 21:40:14 2021 +0000
+++ b/sys/arch/acorn32/stand/boot32/start.S     Sat Feb 06 21:45:38 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: start.S,v 1.3 2008/02/03 14:59:16 chris Exp $  */
+/*     $NetBSD: start.S,v 1.4 2021/02/06 21:45:38 joerg Exp $  */
 
 /*
  * Copyright (c) 2002 Reinoud Zandijk
@@ -50,7 +50,7 @@
         * determine processor architecture version. This is nessisary for the
         * correct coprocessor instruction.
         */
-       mrc     15, 0, r0, c0, c0, 0                                    /* read CPU id in r0                    */
+       mrc     p15, 0, r0, c0, c0, 0                                   /* read CPU id in r0                    */
        mov     r3, r0                                                  /* store in r3                          */
 
        /* assume its ARMv4 instruction set                                                                     */
@@ -77,23 +77,23 @@
        /* flush ID cache                                                                                       */
        mov     r0, #0
        cmp     r14, #0
-       mcreq   15, 0, r0, c7, c0, 0                                    /* flush v3 ID cache                    */
-       mcrne   15, 0, r0, c7, c7, 0                                    /* flush v4 ID cache                    */
-       mcrne   15, 0, r0, c7, c10, 4                                   /* drain WB (v4)                        */
+       mcreq   p15, 0, r0, c7, c0, 0                                   /* flush v3 ID cache                    */
+       mcrne   p15, 0, r0, c7, c7, 0                                   /* flush v4 ID cache                    */
+       mcrne   p15, 0, r0, c7, c10, 4                                  /* drain WB (v4)                        */
 
        /* flush TLB                                                                                            */
-       mcr     15, 0, r0, c5, c0, 0                                    /* flush TLB for v3 and v4              */
+       mcr     p15, 0, r0, c5, c0, 0                                   /* flush TLB for v3 and v4              */
 
        /* switch off MMU, IDcache and WB and branch to physical code space                                     */
        cmp     r14, #0
-       mrcne   15, 0, r0, c1, c0, 0                                    /* read processor control register if v4*/
+       mrcne   p15, 0, r0, c1, c0, 0                                   /* read processor control register if v4*/
        bic     r0, r0, #0x3f                                           /* clear only known bits                */
        moveq   r0, #0                                                  /* for v3 just set to zero              */
        orr     r0, r0, #CPU_CONTROL_LABT_ENABLE | CPU_CONTROL_32BD_ENABLE | CPU_CONTROL_32BP_ENABLE
        mov     r13, r0                                                 /* save this control value in r13       */
        cmp     r14, #0
-       mcr     15, 0, r0, c1, c0, 0                                    /* write control register!              */
-/*1*/  mcrne   15, 0, r1, c7, c5, 0                                    /* write zero in ARMv4 MMU disable      */
+       mcr     p15, 0, r0, c1, c0, 0                                   /* write control register!              */
+/*1*/  mcrne   p15, 0, r1, c7, c5, 0                                   /* write zero in ARMv4 MMU disable      */
 /*2*/  mov     pc, r9                                                  /* branch to physical address           */      
        
 relocate_code_physical_restart:
@@ -132,25 +132,25 @@
        /* flush ID cache                                                                                       */
        mov     r0, #0
        cmp     r14, #0
-       mcreq   15, 0, r0, c7, c0, 0                                    /* flush v3 ID cache                    */
-       mcrne   15, 0, r0, c7, c7, 0                                    /* flush v4 ID cache                    */
+       mcreq   p15, 0, r0, c7, c0, 0                                   /* flush v3 ID cache                    */
+       mcrne   p15, 0, r0, c7, c7, 0                                   /* flush v4 ID cache                    */
 
        /* drain write buffer (v4)                                                                              */
        mov     r0, #0
        cmp     r14, #0
-       mcrne   15, 0, r0, c7, c10, 4                                   /* drain WB (v4)                        */
+       mcrne   p15, 0, r0, c7, c10, 4                                  /* drain WB (v4)                        */
 
        /* flush TLB                                                                                            */
-       mcr     15, 0, r0, c5, c0, 0                                    /* flush TLB for v3 and v4              */
+       mcr     p15, 0, r0, c5, c0, 0                                   /* flush TLB for v3 and v4              */
 
        /* set new TLB address                                                                                  */
        mov     r0, r11
-       mcr     15, 0, r0, c2, c0, 0                                    /* write TLB address                    */
+       mcr     p15, 0, r0, c2, c0, 0                                   /* write TLB address                    */
 
        /* Switch on MMU, IDCache and WB and keep on running on flat translated memory                          */
        orr     r0, r13, #CPU_CONTROL_LABT_ENABLE | CPU_CONTROL_32BD_ENABLE | CPU_CONTROL_32BP_ENABLE
        orr     r0, r0,  #CPU_CONTROL_WBUF_ENABLE | CPU_CONTROL_DC_ENABLE   | CPU_CONTROL_MMU_ENABLE
-       mcr     15, 0, r0, c1, c0, 0                                    /* write register !!!                   */
+       mcr     p15, 0, r0, c1, c0, 0                                   /* write register !!!                   */
        mov     r0, r0                                                  /* flat                                 */
        mov     r0, r0                                                  /* flat                                 */
        /* not flat anymore but we just continue                                                                */
@@ -196,7 +196,7 @@
 
        /* relocate the relocation routine to the given page */
        adr     r6, relocate_code
-       mov     r7, #relocate_table_start - relocate_code       /* get length to copy */
+       ldr     r7, =relocate_table_start - relocate_code       /* get length to copy */
        mov     r8, r0
 relocate_code_loop:
        ldr     r9, [r6], #4
@@ -242,7 +242,7 @@
 
        /* set up info */
        mov     r9, r0                                                  /* save relocated page address          */
-       mov     r7, #relocate_code_physical_restart - relocate_code     /* get offset                           */
+       ldr     r7, =relocate_code_physical_restart - relocate_code     /* get offset                   */
        add     r1, r0, r1                                              /* get physical address                 */
        add     r1, r1, r7                                              /* add offset                           */
        mov     r0, r2                                                  /* put configuration structure in r0    */
diff -r c33658de6ba6 -r 04e3d18a7964 sys/arch/acorn32/stand/nbfs/Makefile
--- a/sys/arch/acorn32/stand/nbfs/Makefile      Sat Feb 06 21:40:14 2021 +0000
+++ b/sys/arch/acorn32/stand/nbfs/Makefile      Sat Feb 06 21:45:38 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.4 2019/08/02 12:06:20 joerg Exp $
+#      $NetBSD: Makefile,v 1.5 2021/02/06 21:45:38 joerg Exp $
 
 PROG=          nbfs
 PROGSOURCE=    rmheader.S rmvers.c nbfs.c rmalloc.c
@@ -13,6 +13,4 @@
 
 CLEANFILES+=   rmvers.c
 
-AFLAGS.rmheader.S= ${${ACTIVE_CC} == "clang":?-no-integrated-as:}
-
 .include "../Makefile.buildboot"
diff -r c33658de6ba6 -r 04e3d18a7964 sys/arch/acorn32/stand/nbfs/rmheader.S
--- a/sys/arch/acorn32/stand/nbfs/rmheader.S    Sat Feb 06 21:40:14 2021 +0000
+++ b/sys/arch/acorn32/stand/nbfs/rmheader.S    Sat Feb 06 21:45:38 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rmheader.S,v 1.4 2006/07/13 16:09:58 bjh21 Exp $       */
+/*     $NetBSD: rmheader.S,v 1.5 2021/02/06 21:45:38 joerg Exp $       */
 
 /*-
  * Copyright (c) 2001, 2006 Ben Harris
@@ -36,6 +36,8 @@
 
 #include "nbfs.h"
 
+.syntax unified
+
 rmbase:
        .word   0                       /* Start code */
        .word   rminit - rmbase         /* Initialisation code */
@@ -97,7 +99,7 @@
        stmfd   r13!, {r14}
        mov     r0, #OSFSControl_AddFS
        adr     r1, rmbase
-       mov     r2, #(fsib - rmbase)
+       ldr     r2, =(fsib - rmbase)
        mov     r3, #0
        swi     XOS_FSControl
        ldmfd   r13!, {pc}              /* If that failed, so do we */
@@ -119,8 +121,8 @@
        
 Lerror:
        teq     pc, pc                  /* In 26-bit mode? */
-       ldmneia r13!, {r14}             /* If so, load up return address */
-       orrnes  pc, r14, #R15_FLAG_V    /* and return setting V flag */
+       ldmfdne r13!, {r14}             /* If so, load up return address */
+       orrsne  pc, r14, #R15_FLAG_V    /* and return setting V flag */
        mrs     r14, cpsr               /* Otherwise get cpsr */
        orr     r14, r14, #PSR_V_bit    /* set V flag */
        msr     cpsr_c, r14             /* put it back */
@@ -176,9 +178,9 @@
 
 fsentry_ret:
        cmp     r0, #0
-       ldmeqfd r13!, {r0-r7, pc}
+       popeq   {r0-r7, pc}
        add     r13, r13, #4
-       ldmfd   r13!, {r1-r7}
+       pop     {r1-r7}
        b       Lerror
 
 rmcmdtbl:



Home | Main Index | Thread Index | Old Index