1*344aa361SAndroid Build Coastguard Worker /* 2*344aa361SAndroid Build Coastguard Worker * Copyright (c) 2015 Google Inc. All rights reserved 3*344aa361SAndroid Build Coastguard Worker * 4*344aa361SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining 5*344aa361SAndroid Build Coastguard Worker * a copy of this software and associated documentation files 6*344aa361SAndroid Build Coastguard Worker * (the "Software"), to deal in the Software without restriction, 7*344aa361SAndroid Build Coastguard Worker * including without limitation the rights to use, copy, modify, merge, 8*344aa361SAndroid Build Coastguard Worker * publish, distribute, sublicense, and/or sell copies of the Software, 9*344aa361SAndroid Build Coastguard Worker * and to permit persons to whom the Software is furnished to do so, 10*344aa361SAndroid Build Coastguard Worker * subject to the following conditions: 11*344aa361SAndroid Build Coastguard Worker * 12*344aa361SAndroid Build Coastguard Worker * The above copyright notice and this permission notice shall be 13*344aa361SAndroid Build Coastguard Worker * included in all copies or substantial portions of the Software. 14*344aa361SAndroid Build Coastguard Worker * 15*344aa361SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 16*344aa361SAndroid Build Coastguard Worker * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 17*344aa361SAndroid Build Coastguard Worker * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 18*344aa361SAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 19*344aa361SAndroid Build Coastguard Worker * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 20*344aa361SAndroid Build Coastguard Worker * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 21*344aa361SAndroid Build Coastguard Worker * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 22*344aa361SAndroid Build Coastguard Worker */ 23*344aa361SAndroid Build Coastguard Worker 24*344aa361SAndroid Build Coastguard Worker #include <lib/sm/smcall.h> 25*344aa361SAndroid Build Coastguard Worker #include <sys/types.h> 26*344aa361SAndroid Build Coastguard Worker 27*344aa361SAndroid Build Coastguard Worker #define SMC_ENTITY_PLATFORM_MONITOR 61 28*344aa361SAndroid Build Coastguard Worker 29*344aa361SAndroid Build Coastguard Worker /* 30*344aa361SAndroid Build Coastguard Worker * SMC calls implemented by EL3 monitor 31*344aa361SAndroid Build Coastguard Worker */ 32*344aa361SAndroid Build Coastguard Worker 33*344aa361SAndroid Build Coastguard Worker /* 34*344aa361SAndroid Build Coastguard Worker * Write character in r1 to debug console 35*344aa361SAndroid Build Coastguard Worker */ 36*344aa361SAndroid Build Coastguard Worker #define SMC_FC_DEBUG_PUTC SMC_FASTCALL_NR(SMC_ENTITY_PLATFORM_MONITOR, 0x0) 37*344aa361SAndroid Build Coastguard Worker 38*344aa361SAndroid Build Coastguard Worker /* 39*344aa361SAndroid Build Coastguard Worker * Get register base address 40*344aa361SAndroid Build Coastguard Worker * r1: SMC_GET_GIC_BASE_GICD or SMC_GET_GIC_BASE_GICC 41*344aa361SAndroid Build Coastguard Worker */ 42*344aa361SAndroid Build Coastguard Worker #define SMC_GET_GIC_BASE_GICD 0 43*344aa361SAndroid Build Coastguard Worker #define SMC_GET_GIC_BASE_GICC 1 44*344aa361SAndroid Build Coastguard Worker #define SMC_GET_GIC_BASE_GICR 2 45*344aa361SAndroid Build Coastguard Worker #define SMC_FC_GET_REG_BASE SMC_FASTCALL_NR(SMC_ENTITY_PLATFORM_MONITOR, 0x1) 46*344aa361SAndroid Build Coastguard Worker #define SMC_FC64_GET_REG_BASE \ 47*344aa361SAndroid Build Coastguard Worker SMC_FASTCALL64_NR(SMC_ENTITY_PLATFORM_MONITOR, 0x1) 48*344aa361SAndroid Build Coastguard Worker 49*344aa361SAndroid Build Coastguard Worker ulong generic_arm64_smc(ulong r0, ulong r1, ulong r2, ulong r3); 50