15c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles)/* 2926b001d589ce2f10facb93dd4b87578ea35a855Torne (Richard Coles) * Copyright (C) 2013 Google Inc. All rights reserved. 35c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * 45c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * Redistribution and use in source and binary forms, with or without 55c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * modification, are permitted provided that the following conditions are 65c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * met: 75c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * 85c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * * Redistributions of source code must retain the above copyright 95c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * notice, this list of conditions and the following disclaimer. 105c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * * Redistributions in binary form must reproduce the above 115c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * copyright notice, this list of conditions and the following disclaimer 125c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * in the documentation and/or other materials provided with the 135c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * distribution. 145c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * * Neither the name of Google Inc. nor the names of its 155c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * contributors may be used to endorse or promote products derived from 165c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * this software without specific prior written permission. 175c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * 185c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 195c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 205c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 215c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 225c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 235c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 245c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 255c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 265c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 275c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 285c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 295c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) */ 305c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) 315c87bf8b86a7c82ef50fb7a89697d8e02e2553beTorne (Richard Coles) 3209380295ba73501a205346becac22c6978e4671dTorne (Richard Coles)/* 3309380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) * typedef void (*PushAllRegistersCallback)(SafePointBarrier*, ThreadState*, intptr_t*); 3409380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) * extern "C" void pushAllRegisters(SafePointBarrier*, ThreadState*, PushAllRegistersCallback) 3509380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) */ 3693ac45cfc74041c8ae536ce58a9534d46db2024eTorne (Richard Coles) 3709380295ba73501a205346becac22c6978e4671dTorne (Richard Coles).type pushAllRegisters, %function 3809380295ba73501a205346becac22c6978e4671dTorne (Richard Coles).global pushAllRegisters 3909380295ba73501a205346becac22c6978e4671dTorne (Richard Coles).hidden pushAllRegisters 40d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)#ifdef __thumb__ 41d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)/* In THUMB Mode jump to ARM stub via bx to ensure CPU mode switch. 42d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) * FIXME: This trampoline is provided to workaround bugs in 43d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) * the THUMB/ARM interworking that appear in the component build. 44d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) * When these issues are resolved this stub can be removed. 45d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) */ 46aafa69cb17c9d6606c07663ade5f81388a2c5986Ben Murdoch.align 2 47d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles).code 16 48d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles).thumb_func 49d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)pushAllRegisters: 50d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) adr r3, pushAllRegistersARM 51d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) bx r3 52d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles) 53d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles).type pushAllRegistersARM, %function 54d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles).hidden pushAllRegistersARM 55aafa69cb17c9d6606c07663ade5f81388a2c5986Ben Murdoch.align 4 56d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles).code 32 57d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)pushAllRegistersARM: 58d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)#else 59d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)/* ARM Mode */ 60aafa69cb17c9d6606c07663ade5f81388a2c5986Ben Murdoch.align 4 61aafa69cb17c9d6606c07663ade5f81388a2c5986Ben Murdoch.code 32 6209380295ba73501a205346becac22c6978e4671dTorne (Richard Coles)pushAllRegisters: 63d5428f32f5d1719f774f62e19147104ca245a3abTorne (Richard Coles)#endif 6409380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) /* Push all callee-saved registers and save return address. */ 6509380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) push {r4-r11, lr} 6609380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) /* Pass the two first arguments unchanged (r0, r1) 6709380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) * and pass the stack pointer after pushing callee-saved 6809380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) * registers to the callback function. 6909380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) */ 7009380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) mov r3, r2 7109380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) mov r2, sp 7209380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) blx r3 7309380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) /* Discard all the registers, and pop lr into pc which returns 7409380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) * and switches mode if needed. 7509380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) */ 7609380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) add sp, sp, #32 7709380295ba73501a205346becac22c6978e4671dTorne (Richard Coles) pop {pc} 78