Changeset 9db5b66 in mainline


Ignore:
Timestamp:
2005-05-11T00:14:42Z (20 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
00a44bc
Parents:
79f1f38f
Message:

Move architecture independent memcopy() and memsetb() out of MIPS subtree and place them in src/lib/ as _memcopy() and _memsetb().
Add MIPS native memsetb().
Add IA-64 native memcpy().

More complete and *almost* functional versions of IA-64 context_save() and context_restore().

Files:
1 added
7 edited
1 moved

Legend:

Unmodified
Added
Removed
  • arch/ia64/Makefile.inc

    r79f1f38f r9db5b66  
    1717arch_sources= \
    1818        arch/start.S \
     19        arch/asm.S \
    1920        arch/fake.s \
    2021        arch/putchar.c \
  • arch/ia64/include/context.h

    r79f1f38f r9db5b66  
    3232#include <arch/types.h>
    3333
    34 
    35 
    3634struct context {
    37         __u64 sp;
    38         __u64 pc;
     35        __u64 r1;
     36        __u64 r2;
     37        __u64 r3;
     38        __u64 r4;
     39        __u64 r5;
     40        __u64 r6;
     41        __u64 r7;
     42        __u64 r8;
     43        __u64 r9;
     44        __u64 r10;
     45        __u64 r11;
     46        __u64 sp;               /* r12 */
     47        __u64 r13;
     48        __u64 r14;
     49        __u64 r15;
     50        __u64 r16;
     51        __u64 r17;
     52        __u64 r18;
     53        __u64 r19;
     54        __u64 r20;
     55        __u64 r21;
     56        __u64 r22;
     57        __u64 r23;
     58        __u64 r24;
     59        __u64 r25;
     60        __u64 r26;
     61        __u64 r27;
     62        __u64 r28;
     63        __u64 r29;
     64        __u64 r30;
     65        __u64 r31;
     66        __u64 pc;               /* b0 */
    3967        pri_t pri;
    40 };
     68} __attribute__ ((packed));
    4169
    4270#endif
  • arch/ia64/src/context.S

    r79f1f38f r9db5b66  
    3333
    3434context_save:
     35        alloc loc0 = ar.pfs, 1, 2, 0, 0
     36       
     37        /*
     38         * TODO: save the rest of the context registers.
     39         */
     40
     41        st8 [in0] = r1, 8       ;;
     42        st8 [in0] = r2, 8       ;;
     43        st8 [in0] = r3, 8       ;;
     44        st8 [in0] = r4, 8       ;;
     45        st8 [in0] = r5, 8       ;;
     46        st8 [in0] = r6, 8       ;;
     47        st8 [in0] = r7, 8       ;;
     48        st8 [in0] = r8, 8       ;;
     49        st8 [in0] = r9, 8       ;;
     50        st8 [in0] = r10, 8      ;;
     51        st8 [in0] = r11, 8      ;;
     52        st8 [in0] = r12, 8      ;;      /* save sp */
     53        st8 [in0] = r13, 8      ;;
     54        st8 [in0] = r14, 8      ;;
     55        st8 [in0] = r15, 8      ;;
     56        st8 [in0] = r16, 8      ;;
     57        st8 [in0] = r17, 8      ;;
     58        st8 [in0] = r18, 8      ;;
     59        st8 [in0] = r19, 8      ;;
     60        st8 [in0] = r20, 8      ;;
     61        st8 [in0] = r21, 8      ;;
     62        st8 [in0] = r22, 8      ;;
     63        st8 [in0] = r23, 8      ;;
     64        st8 [in0] = r24, 8      ;;
     65        st8 [in0] = r25, 8      ;;
     66        st8 [in0] = r26, 8      ;;
     67        st8 [in0] = r27, 8      ;;
     68        st8 [in0] = r28, 8      ;;
     69        st8 [in0] = r29, 8      ;;
     70        st8 [in0] = r30, 8      ;;
     71        st8 [in0] = r31, 8      ;;
     72
     73        /* save pc */
     74        mov loc1 = b0           ;;
     75        st8 [in0] = loc1, 8
     76       
     77        mov ar.pfs = loc0
     78       
     79        add r8 = r0, r0, 1              /* context_save returns 1 */
    3580        br.ret.sptk.many rp
    3681
    3782context_restore:
     83        alloc loc0 = ar.pfs, 1, 2, 0, 0
     84
     85        /*
     86         * TODO: restore the rest of the context registers.
     87         */
     88       
     89        ld8 r1 = [in0], 8       ;;
     90        ld8 r2 = [in0], 8       ;;
     91        ld8 r3 = [in0], 8       ;;
     92        ld8 r4 = [in0], 8       ;;
     93        ld8 r5 = [in0], 8       ;;
     94        ld8 r6 = [in0], 8       ;;
     95        ld8 r7 = [in0], 8       ;;
     96        ld8 r8 = [in0], 8       ;;
     97        ld8 r9 = [in0], 8       ;;
     98        ld8 r10 = [in0], 8      ;;
     99        ld8 r11 = [in0], 8      ;;
     100        ld8 r12 = [in0], 8      ;;      /* restore sp */
     101        ld8 r13 = [in0], 8      ;;
     102        ld8 r14 = [in0], 8      ;;
     103        ld8 r15 = [in0], 8      ;;
     104        ld8 r16 = [in0], 8      ;;
     105        ld8 r17 = [in0], 8      ;;
     106        ld8 r18 = [in0], 8      ;;
     107        ld8 r19 = [in0], 8      ;;
     108        ld8 r20 = [in0], 8      ;;
     109        ld8 r21 = [in0], 8      ;;
     110        ld8 r22 = [in0], 8      ;;
     111        ld8 r23 = [in0], 8      ;;
     112        ld8 r24 = [in0], 8      ;;
     113        ld8 r25 = [in0], 8      ;;
     114        ld8 r26 = [in0], 8      ;;
     115        ld8 r27 = [in0], 8      ;;
     116        ld8 r28 = [in0], 8      ;;
     117        ld8 r29 = [in0], 8      ;;
     118        ld8 r30 = [in0], 8      ;;
     119        ld8 r31 = [in0], 8      ;;
     120
     121        /* restore pc */
     122        ld8 loc1 = [in0], 8     ;;
     123        mov b0 = loc1
     124       
     125        mov ar.pfs = loc0
     126       
     127        mov r8 = r0                     /* context_restore returns 0 */
    38128        br.ret.sptk.many rp
  • arch/mips/Makefile.inc

    r79f1f38f r9db5b66  
    2727        arch/interrupt.c \
    2828        arch/cache.c \
    29         arch/lib/memstr.c \
    3029        arch/cpu/cpu.c \
    3130        arch/mm/frame.c \
  • arch/mips/src/asm.s

    r79f1f38f r9db5b66  
    144144
    145145
     146.global memsetb
     147memsetb:
     148        j _memsetb
     149        nop
     150
    146151# THIS IS USERSPACE CODE
    147152.global utext
  • include/memstr.h

    r79f1f38f r9db5b66  
    3939extern int memcmp(__address src, __address dst, int cnt);
    4040
     41/*
     42 * Architecture independent variants.
     43 */
     44extern void _memcopy(__address src, __address dst, int cnt);
     45extern void _memsetb(__address dst, int cnt, __u8 x);
     46
    4147#endif
  • src/Makefile

    r79f1f38f r9db5b66  
    1616        lib/func.c \
    1717        lib/list.c \
     18        lib/memstr.c \
    1819        debug/print.c \
    1920        time/clock.c \
  • src/lib/memstr.c

    r79f1f38f r9db5b66  
    3030#include <arch/types.h>
    3131
    32 void memcopy(__address src, __address dst, int cnt)
     32void _memcopy(__address src, __address dst, int cnt)
    3333{
    3434        int i;
     
    3838}
    3939
    40 void memsetb(__address dst, int cnt, __u8 x)
     40void _memsetb(__address dst, int cnt, __u8 x)
    4141{
    4242        int i;
Note: See TracChangeset for help on using the changeset viewer.