/** @file sys_main.c * @brief Application main file * @date 11-Dec-2018 * @version 04.07.01 * * This file contains an empty main function, * which can be used for the application. */ /* * Copyright (C) 2009-2018 Texas Instruments Incorporated - www.ti.com * * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the * distribution. * * Neither the name of Texas Instruments Incorporated nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ /* USER CODE BEGIN (0) */ /* USER CODE END */ /* Include Files */ #include "sys_common.h" /* USER CODE BEGIN (1) */ #include "system.h" #include "sys_dma.h" #include "adc.h" #include "can.h" #include "etpwm.h" #include "gio.h" #include "mibspi.h" #include "sci.h" #include "rti.h" #include "DGCommon.h" #include "AlarmMgmt.h" #include "CommBuffers.h" #include "CPLD.h" #include "FPGA.h" #include "InternalADC.h" #include "MsgQueues.h" #include "OperationModes.h" #include "Reservoirs.h" #include "RTC.h" #include "SafetyShutdown.h" #include "SystemComm.h" #include "TaskBG.h" #include "TemperatureSensors.h" #include "Timers.h" #include "WatchdogMgmt.h" #include "Heaters.h" static void initProcessor( void ); static void initSoftware( void ); static void initHardware( void ); static void initTasks( void ); /* USER CODE END */ /** @fn void main(void) * @brief Application main function * @note This function is empty by default. * * This function is called after startup. * The user can use this function to implement the application. */ /* USER CODE BEGIN (2) */ /* USER CODE END */ int main(void) { /* USER CODE BEGIN (3) */ initProcessor(); // configure processor initSoftware(); // initialize software modules initHardware(); // configure external hardware initTasks(); // setup and start the scheduled tasks // start task background (will not return) #ifndef _VECTORCAST_ taskBackground(); #endif /* USER CODE END */ return 0; } /* USER CODE BEGIN (4) */ /************************************************************************* * @brief initProcessor * The initProcessor function initializes and configures the processor \n * peripherals. * @details * Inputs : none * Outputs : Processor peripherals initialized and configured. * @return none *************************************************************************/ static void initProcessor( void ) { gioInit(); // configure GPIO pins adcInit(); // configure internal ADC channels mibspiInit(); // configure MIBSPI3 and re-purpose MIBSPI1 & 5 pins for GPIO etpwmInit(); // configure PWMs etpwmSetCmpA( etpwmREG1, 0 ); etpwmSetCmpB( etpwmREG1, 0 ); etpwmSetCmpB( etpwmREG2, 0 ); etpwmSetCmpA( etpwmREG3, 0 ); etpwmSetCmpA( etpwmREG6, 0 ); etpwmSetCmpB( etpwmREG6, 0 ); etpwmStartTBCLK(); canInit(); // CAN1 = CAN, re-purposing CAN2 and CAN3 Rx and Tx pins as GPIO sciInit(); // SCI1 used for PC serial interface, SCI2 used for FPGA serial interface dmaEnable(); // enable DMA } /************************************************************************* * @brief initSoftware * The initSoftware function calls all software module initialize functions. * @details * Inputs : none * Outputs : All modules initialized. * @return none *************************************************************************/ static void initSoftware( void ) { initTimers(); initSafetyShutdown(); initCPLD(); initAlarmMgmt(); initWatchdogMgmt(); initFPGA(); initInternalADC(); initRTC(); initCommBuffers(); initMsgQueues(); initSystemComm(); initReservoirs(); initOperationModes(); initTemperatureSensors(); initHeaters(); } /************************************************************************* * @brief initHardware * The initHardware function initializes and configures external hardware. * @details * Inputs : none * Outputs : External hardware initialized and configured. * @return none *************************************************************************/ static void initHardware( void ) { } /************************************************************************* * @brief initTasks * The initTasks function sets up and starts the scheduled tasks. * @details * Inputs : none * Outputs : Scheduled tasks set up and started. * @return none *************************************************************************/ static void initTasks( void ) { // initialize RTI to setup the 3 tasks rtiInit(); rtiEnableNotification( rtiNOTIFICATION_COMPARE0 | rtiNOTIFICATION_COMPARE1 | rtiNOTIFICATION_COMPARE3 ); rtiStartCounter( rtiCOUNTER_BLOCK0 ); // the timer task (and other comm related interrupts) require FIQ enabled _enable_FIQ(); // the general and priority tasks require IRQ enabled _enable_IRQ(); } /* USER CODE END */