Changeset c621f4aa in mainline for uspace/lib/c/arch/ppc32
- Timestamp:
- 2010-07-25T10:11:13Z (16 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 377cce8
- Parents:
- 24a2517 (diff), a2da43c (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)links above to see all the changes relative to each parent. - Location:
- uspace/lib/c/arch/ppc32
- Files:
-
- 24 moved
-
Makefile.common (moved) (moved from boot/arch/ppc32/loader/boot.S ) (1 diff)
-
Makefile.inc (moved) (moved from uspace/lib/libc/arch/sparc64/Makefile.inc ) (1 diff)
-
_link.ld.in (moved) (moved from uspace/lib/libc/arch/ppc32/_link.ld.in ) (1 diff)
-
include/atomic.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/atomic.h ) (6 diffs)
-
include/config.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/config.h )
-
include/ddi.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/ddi.h )
-
include/faddr.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/faddr.h )
-
include/fibril.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/fibril.h )
-
include/inttypes.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/inttypes.h )
-
include/istate.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/istate.h )
-
include/limits.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/limits.h )
-
include/regname.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/regname.h )
-
include/stackarg.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/stackarg.h )
-
include/syscall.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/syscall.h )
-
include/thread.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/thread.h )
-
include/tls.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/tls.h )
-
include/types.h (moved) (moved from uspace/lib/libc/arch/ppc32/include/types.h ) (3 diffs)
-
src/entry.s (moved) (moved from uspace/lib/libc/arch/ppc32/src/entry.s )
-
src/fibril.S (moved) (moved from uspace/lib/libc/arch/ppc32/src/fibril.S )
-
src/stacktrace.c (moved) (moved from uspace/lib/libc/arch/ppc32/src/stacktrace.c )
-
src/stacktrace_asm.S (moved) (moved from uspace/lib/libc/arch/ppc32/src/stacktrace_asm.S )
-
src/syscall.c (moved) (moved from uspace/lib/libc/arch/ppc32/src/syscall.c )
-
src/thread_entry.s (moved) (moved from uspace/lib/libc/arch/ppc32/src/thread_entry.s )
-
src/tls.c (moved) (moved from uspace/lib/libc/arch/ppc32/src/tls.c )
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/c/arch/ppc32/Makefile.common
r24a2517 rc621f4aa 27 27 # 28 28 29 #include "regname.h" 29 GCC_CFLAGS += -mcpu=powerpc -msoft-float -m32 30 AFLAGS = -a32 30 31 31 .section BOOTSTRAP, "ax" 32 ENDIANESS = BE 32 33 33 .global start 34 35 start: 36 lis r4, ofw_cif@ha 37 addi r4, r4, ofw_cif@l 38 stw r5, 0(r4) 39 40 bl ofw_init 41 42 b bootstrap 34 BFD_NAME = elf32-powerpc 35 BFD_ARCH = powerpc:common -
uspace/lib/c/arch/ppc32/Makefile.inc
r24a2517 rc621f4aa 27 27 # 28 28 29 ## Toolchain configuration 30 # 31 32 TARGET = sparc64-linux-gnu 33 TOOLCHAIN_DIR = $(CROSS_PREFIX)/sparc64/bin 34 35 ARCH_SOURCES += arch/$(UARCH)/src/fibril.S \ 29 ARCH_SOURCES = \ 30 arch/$(UARCH)/src/entry.s \ 31 arch/$(UARCH)/src/thread_entry.s \ 32 arch/$(UARCH)/src/syscall.c \ 33 arch/$(UARCH)/src/fibril.S \ 36 34 arch/$(UARCH)/src/tls.c \ 37 35 arch/$(UARCH)/src/stacktrace.c \ 38 36 arch/$(UARCH)/src/stacktrace_asm.S 39 37 40 GCC_CFLAGS += -mcpu=ultrasparc -m64 41 LFLAGS += -no-check-sections -N 42 43 ENDIANESS = BE 44 45 BFD_NAME = elf64-sparc 46 BFD_ARCH = sparc 38 .PRECIOUS: arch/$(UARCH)/src/entry.o -
uspace/lib/c/arch/ppc32/_link.ld.in
r24a2517 rc621f4aa 1 STARTUP(LIBC_P REFIX/arch/UARCH/src/entry.o)1 STARTUP(LIBC_PATH/arch/UARCH/src/entry.o) 2 2 ENTRY(__entry) 3 3 -
uspace/lib/c/arch/ppc32/include/atomic.h
r24a2517 rc621f4aa 27 27 */ 28 28 29 /** @addtogroup libcppc32 29 /** @addtogroup libcppc32 30 30 * @{ 31 31 */ … … 42 42 static inline void atomic_inc(atomic_t *val) 43 43 { 44 longtmp;45 44 atomic_count_t tmp; 45 46 46 asm volatile ( 47 47 "1:\n" … … 50 50 "stwcx. %0, 0, %2\n" 51 51 "bne- 1b" 52 : "=&r" (tmp), "=m" (val->count) 53 : "r" (&val->count), "m" (val->count) 54 : "cc"); 52 : "=&r" (tmp), 53 "=m" (val->count) 54 : "r" (&val->count), 55 "m" (val->count) 56 : "cc" 57 ); 55 58 } 56 59 57 60 static inline void atomic_dec(atomic_t *val) 58 61 { 59 longtmp;60 62 atomic_count_t tmp; 63 61 64 asm volatile ( 62 65 "1:\n" 63 66 "lwarx %0, 0, %2\n" 64 67 "addic %0, %0, -1\n" 65 "stwcx. %0, 0, %2\n"68 "stwcx. %0, 0, %2\n" 66 69 "bne- 1b" 67 : "=&r" (tmp), "=m" (val->count) 68 : "r" (&val->count), "m" (val->count) 69 : "cc"); 70 : "=&r" (tmp), 71 "=m" (val->count) 72 : "r" (&val->count), 73 "m" (val->count) 74 : "cc" 75 ); 70 76 } 71 77 72 static inline longatomic_postinc(atomic_t *val)78 static inline atomic_count_t atomic_postinc(atomic_t *val) 73 79 { 74 80 atomic_inc(val); … … 76 82 } 77 83 78 static inline longatomic_postdec(atomic_t *val)84 static inline atomic_count_t atomic_postdec(atomic_t *val) 79 85 { 80 86 atomic_dec(val); … … 82 88 } 83 89 84 static inline longatomic_preinc(atomic_t *val)90 static inline atomic_count_t atomic_preinc(atomic_t *val) 85 91 { 86 92 atomic_inc(val); … … 88 94 } 89 95 90 static inline longatomic_predec(atomic_t *val)96 static inline atomic_count_t atomic_predec(atomic_t *val) 91 97 { 92 98 atomic_dec(val); -
uspace/lib/c/arch/ppc32/include/types.h
r24a2517 rc621f4aa 27 27 */ 28 28 29 /** @addtogroup libcppc32 29 /** @addtogroup libcppc32 30 30 * @{ 31 31 */ … … 38 38 #define __32_BITS__ 39 39 40 typedef unsigned int sysarg_t; 40 #include <libarch/common.h> 41 41 42 typedef char int8_t; 43 typedef short int int16_t; 44 typedef int int32_t; 45 typedef long long int int64_t; 42 #define SIZE_MIN UINT32_MIN 43 #define SIZE_MAX UINT32_MAX 46 44 47 typedef unsigned char uint8_t; 48 typedef unsigned short int uint16_t; 49 typedef unsigned int uint32_t; 50 typedef u nsigned long long int uint64_t;45 #define SSIZE_MIN INT32_MIN 46 #define SSIZE_MAX INT32_MAX 47 48 typedef uint32_t sysarg_t; 51 49 52 50 typedef int32_t ssize_t; … … 54 52 55 53 typedef uint32_t uintptr_t; 54 typedef uint32_t atomic_count_t; 55 typedef int32_t atomic_signed_t; 56 56 57 57 #endif
Note:
See TracChangeset
for help on using the changeset viewer.
