/* IBM_PROLOG_BEGIN_TAG */ /* This is an automatically generated prolog. */ /* */ /* $Source: src/kernel/terminate.C $ */ /* */ /* OpenPOWER HostBoot Project */ /* */ /* Contributors Listed Below - COPYRIGHT 2012,2019 */ /* [+] International Business Machines Corp. */ /* */ /* */ /* Licensed under the Apache License, Version 2.0 (the "License"); */ /* you may not use this file except in compliance with the License. */ /* You may obtain a copy of the License at */ /* */ /* http://www.apache.org/licenses/LICENSE-2.0 */ /* */ /* Unless required by applicable law or agreed to in writing, software */ /* distributed under the License is distributed on an "AS IS" BASIS, */ /* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or */ /* implied. See the License for the specific language governing */ /* permissions and limitations under the License. */ /* */ /* IBM_PROLOG_END_TAG */ #include #include #include #include #include #ifndef BOOTLOADER #include #include #include #include #include #endif // BOOTLOADER extern "C" void p9_force_attn() NO_RETURN; #ifndef BOOTLOADER mutex_t g_kernelMutex; /* Instance of the TI Data Area */ HB_TI_DataArea kernel_TIDataArea = {}; /* Instance of the HB descriptor struct */ HB_Descriptor kernel_hbDescriptor = { &kernel_TIDataArea, &KernelIpc::ipc_data_area, 0 }; #endif // BOOTLOADER void terminateExecuteTI() { // Trigger a hostboot dump in Simics MAGIC_INSTRUCTION(MAGIC_HB_DUMP); // Call the function that actually executes the TI code. p9_force_attn(); } void initKernelTIMutex() { #ifndef BOOTLOADER mutex_init(&g_kernelMutex); #endif } #ifndef BOOTLOADER void termWritePlid(uint16_t i_source, uint32_t plid) { kernel_TIDataArea.type = TI_WITH_PLID; kernel_TIDataArea.source = i_source; kernel_TIDataArea.plid = plid; } #endif // BOOTLOADER void termWriteSRC(uint16_t i_source, uint16_t i_reasoncode,uint64_t i_failAddr, uint32_t i_error_data, bool i_forceWrite) { #ifndef BOOTLOADER mutex_lock(&g_kernelMutex); #endif // If this is the first TI on the system or if i_forceWrite is true, then // overwrite the HB TI area with the given info. Unless i_forceWrite is // true, all subsequent TI codes will NOT overwrite the original TI // information. if(kernel_TIDataArea.src.reasoncode == NO_TI_ERROR || i_forceWrite) { // Update the TI structure with the type of TI, who called, // and extra error data (if applicable, otherwise 0) kernel_TIDataArea.type = TI_WITH_SRC; kernel_TIDataArea.source = i_source; kernel_TIDataArea.error_data = i_error_data; // Update TID data area with the SRC info we have avail kernel_TIDataArea.src.ID = 0xBC; kernel_TIDataArea.src.subsystem = 0x8A; kernel_TIDataArea.src.reasoncode = i_reasoncode; kernel_TIDataArea.src.moduleID = 0; kernel_TIDataArea.src.iType = TI_WITH_SRC; kernel_TIDataArea.src.iSource = i_source; // Update User Data with address of fail location kernel_TIDataArea.src.word6 = i_failAddr; } #ifndef BOOTLOADER mutex_unlock(&g_kernelMutex); #endif } void termModifySRC(uint8_t i_moduleID, uint32_t i_word7, uint32_t i_word8) { // Update module ID kernel_TIDataArea.src.moduleID = i_moduleID; // Update User Data with anything supplied for word7 or word8 kernel_TIDataArea.src.word7 = i_word7; kernel_TIDataArea.src.word8 = i_word8; } #ifndef BOOTLOADER void termSetHbDump(void) { // Set indicator flag for doing HB dump kernel_TIDataArea.hbDumpFlag = 1; return; } void termSetIstep(uint32_t i_istep) { // Set istep into progress code word of the SRC kernel_TIDataArea.src.SRCword4 = i_istep; return; } #endif // BOOTLOADER