[BACK]Return to arch.h CVS log [TXT][DIR] Up to [local] / prex-old / sys / arch / arm / include

Annotation of prex-old/sys/arch/arm/include/arch.h, Revision 1.1.1.1.2.1

1.1       nbrk        1: /*
                      2:  * Copyright (c) 2005, Kohsuke Ohtani
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms, with or without
                      6:  * modification, are permitted provided that the following conditions
                      7:  * are met:
                      8:  * 1. Redistributions of source code must retain the above copyright
                      9:  *    notice, this list of conditions and the following disclaimer.
                     10:  * 2. Redistributions in binary form must reproduce the above copyright
                     11:  *    notice, this list of conditions and the following disclaimer in the
                     12:  *    documentation and/or other materials provided with the distribution.
                     13:  * 3. Neither the name of the author nor the names of any co-contributors
                     14:  *    may be used to endorse or promote products derived from this software
                     15:  *    without specific prior written permission.
                     16:  *
                     17:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
                     18:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     19:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     20:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
                     21:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     22:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     23:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     24:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     25:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     26:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     27:  * SUCH DAMAGE.
                     28:  */
                     29:
                     30: #ifndef _ARCH_H
                     31: #define _ARCH_H
                     32:
                     33: /**
                     34:  * ARM register reference:
                     35:  *
                     36:  *  Name    Number     ARM Procedure Calling Standard Role
                     37:  *
                     38:  *  a1     r0          argument 1 / integer result / scratch register / argc
                     39:  *  a2     r1          argument 2 / scratch register / argv
                     40:  *  a3     r2          argument 3 / scratch register / envp
                     41:  *  a4     r3          argument 4 / scratch register
                     42:  *  v1     r4          register variable
                     43:  *  v2     r5          register variable
                     44:  *  v3     r6          register variable
                     45:  *  v4     r7          register variable
                     46:  *  v5     r8          register variable
                     47:  *  sb/v6   r9         static base / register variable
                     48:  *  sl/v7   r10                stack limit / stack chunk handle / reg. variable
                     49:  *  fp     r11         frame pointer
                     50:  *  ip     r12         scratch register / new-sb in inter-link-unit calls
                     51:  *  sp     r13         lower end of current stack frame
                     52:  *  lr     r14         link address / scratch register
                     53:  *  pc     r15         program counter
                     54:  */
                     55:
                     56: /*
                     57:  * Common register frame for trap/interrupt.
                     58:  * These cpu state are saved into top of the kernel stack in
                     59:  * trap/interrupt entries. Since the arguments of system calls are
                     60:  * passed via registers, the system call library is completely
                     61:  * dependent on this register format.
                     62:  */
                     63: struct cpu_regs {
                     64:        u_long  r0;     /*  +0 (00) */
                     65:        u_long  r1;     /*  +4 (04) */
                     66:        u_long  r2;     /*  +8 (08) */
                     67:        u_long  r3;     /* +12 (0C) */
                     68:        u_long  r4;     /* +16 (10) */
                     69:        u_long  r5;     /* +20 (14) */
                     70:        u_long  r6;     /* +24 (18) */
                     71:        u_long  r7;     /* +28 (1C) */
                     72:        u_long  r8;     /* +32 (20) */
                     73:        u_long  r9;     /* +36 (24) */
                     74:        u_long  r10;    /* +40 (28) */
                     75:        u_long  r11;    /* +44 (2C) */
                     76:        u_long  r12;    /* +48 (30) */
                     77:        u_long  sp;     /* +52 (34) */
                     78:        u_long  lr;     /* +56 (38) */
                     79:        u_long  svc_sp; /* +60 (3C) */
                     80:        u_long  svc_lr; /* +64 (40) */
                     81:        u_long  pc;     /* +68 (44) */
                     82:        u_long  cpsr;   /* +72 (48) */
                     83: };
                     84:
                     85: /*
                     86:  * Kernel mode context for context switching.
                     87:  */
                     88: struct kern_regs {
                     89:        u_long  r4;
                     90:        u_long  r5;
                     91:        u_long  r6;
                     92:        u_long  r7;
                     93:        u_long  r8;
                     94:        u_long  r9;
                     95:        u_long  r10;
                     96:        u_long  r11;
                     97:        u_long  sp;
                     98:        u_long  lr;
                     99: };
                    100:
                    101: /*
                    102:  * Processor context
                    103:  */
                    104: struct context {
1.1.1.1.2.1! nbrk      105:        struct kern_regs kregs;         /* kernel mode registers */
        !           106:        struct cpu_regs *uregs;         /* user mode registers */
        !           107:        struct cpu_regs *saved_regs;    /* savecd user mode registers */
1.1       nbrk      108: };
                    109:
                    110: typedef struct context *context_t;     /* context id */
                    111:
1.1.1.1.2.1! nbrk      112: /* types for context_set */
        !           113: #define CTX_KSTACK     0               /* set kernel mode entry address */
        !           114: #define CTX_KENTRY     1               /* set kernel mode entry address */
        !           115: #define CTX_KARG       2               /* set kernel mode argument */
        !           116: #define CTX_USTACK     3               /* set user mode stack address */
        !           117: #define CTX_UENTRY     4               /* set user mode entry addres */
        !           118: #define CTX_UARG       5               /* set user mode argument */
        !           119:
        !           120: extern void    context_set(context_t, int, vaddr_t);
        !           121: extern void    context_switch(context_t, context_t);
        !           122: extern void    context_save(context_t);
        !           123: extern void    context_restore(context_t);
1.1       nbrk      124:
                    125: /*
                    126:  * Memory Management Unit
                    127:  */
                    128:
                    129: typedef long *pgd_t;                           /* Page directory */
                    130:
                    131: /* Memory page type */
                    132: #define PG_UNMAP       0               /* no page */
                    133: #define PG_READ                1               /* read only */
                    134: #define PG_WRITE       2               /* read/write */
                    135:
                    136: #ifdef CONFIG_MMU
                    137: extern void mmu_init(void);
                    138: extern int  mmu_map(pgd_t, void *, void *, size_t, int);
                    139: extern pgd_t mmu_newmap(void);
                    140: extern void mmu_delmap(pgd_t);
                    141: extern void mmu_switch(pgd_t);
                    142: extern void *mmu_extract(pgd_t, void *, size_t);
                    143: #else /* CONFIG_MMU */
                    144: #define mmu_init()             do {} while (0)
                    145: #endif /* !CONFIG_MMU */
                    146:
                    147: /*
                    148:  * User Memory access
                    149:  */
1.1.1.1.2.1! nbrk      150: extern int umem_copyin(const void *, void *, size_t);
        !           151: extern int umem_copyout(const void *, void *, size_t);
1.1       nbrk      152: extern int umem_strnlen(const char *, size_t, size_t *);
                    153:
1.1.1.1.2.1! nbrk      154: extern void     syscall_ret(void);
1.1       nbrk      155: #define breakpoint()           do {} while (0);
                    156:
                    157: #endif /* !_ARCH_H */

CVSweb