URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [boehm-gc/] [sparc_mach_dep.S] - Rev 721
Compare with Previous | Blame | View Log
! SPARCompiler 3.0 and later apparently no longer handles! asm outside functions. So we need a separate .s file! This is only set up for SunOS 5, not SunOS 4.! Assumes this is called before the stack contents are! examined..seg "text".globl GC_save_regs_in_stack.globl GC_push_regsGC_save_regs_in_stack:GC_push_regs:#if defined(__arch64__) || defined(__sparcv9)save %sp,-128,%spflushwretrestore %sp,2047+128,%o0#else /* 32 bit SPARC */ta 0x3 ! ST_FLUSH_WINDOWSmov %sp,%o0retlnop#endif /* 32 bit SPARC */.GC_save_regs_in_stack_end:.size GC_save_regs_in_stack,.GC_save_regs_in_stack_end-GC_save_regs_in_stack.globl GC_clear_stack_innerGC_clear_stack_inner:#if defined(__arch64__) || defined(__sparcv9)mov %sp,%o2 ! Save spadd %sp,2047-8,%o3 ! p = sp+bias-8add %o1,-2047-192,%sp ! Move sp out of the way,! so that traps still work.! Includes some extra words! so we can be sloppy below.loop:stx %g0,[%o3] ! *(long *)p = 0cmp %o3,%o1bgu,pt %xcc, loop ! if (p > limit) goto loopadd %o3,-8,%o3 ! p -= 8 (delay slot)retlmov %o2,%sp ! Restore sp., delay slot#else /* 32 bit SPARC */mov %sp,%o2 ! Save spadd %sp,-8,%o3 ! p = sp-8clr %g1 ! [g0,g1] = 0add %o1,-0x60,%sp ! Move sp out of the way,! so that traps still work.! Includes some extra words! so we can be sloppy below.loop:std %g0,[%o3] ! *(long long *)p = 0cmp %o3,%o1bgu loop ! if (p > limit) goto loopadd %o3,-8,%o3 ! p -= 8 (delay slot)retlmov %o2,%sp ! Restore sp., delay slot#endif /* 32 bit SPARC */.GC_clear_stack_inner_end:.size GC_clear_stack_inner,.GC_clear_stack_inner_end-GC_clear_stack_inner
