mirror of
https://github.com/STMicroelectronics/STM32CubeF0.git
synced 2025-05-03 22:17:10 +08:00
397 lines
12 KiB
C
397 lines
12 KiB
C
/**
|
|
******************************************************************************
|
|
* @file CEC/CEC_MultiAddress/Src/main.c
|
|
* @author MCD Application Team
|
|
* @brief This example describes how to configure and use the CEC through
|
|
* the STM32F0xx HAL API.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* <h2><center>© Copyright (c) 2016 STMicroelectronics.
|
|
* All rights reserved.</center></h2>
|
|
*
|
|
* This software component is licensed by ST under BSD 3-Clause license,
|
|
* the "License"; You may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at:
|
|
* opensource.org/licenses/BSD-3-Clause
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include "main.h"
|
|
|
|
/** @addtogroup STM32F0xx_HAL_Examples
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup CEC_MultiAddress
|
|
* @{
|
|
*/
|
|
|
|
/* Private typedef -----------------------------------------------------------*/
|
|
/* Private define ------------------------------------------------------------*/
|
|
/* Private macro -------------------------------------------------------------*/
|
|
/* Private variables ---------------------------------------------------------*/
|
|
uint8_t Tab_Rx[CEC_MAX_PAYLOAD]; /* Received data buffer. Max size = 16 bytes
|
|
* header + opcode followed by up to 14 operands */
|
|
uint8_t Tab_Tx[CEC_MAX_PAYLOAD-1]; /* Transmitted data buffer.
|
|
* header is not included in Tab_Tx.
|
|
* Max size = 15 bytes.
|
|
* one opcode followed by up to 14 operands.
|
|
* When payload size = 0, only the header is sent
|
|
* (ping operation) */
|
|
uint8_t ReceivedFrame = 0x0; /* Set when a reception occurs */
|
|
uint16_t NbOfReceivedBytes = 0x0; /* Number of received bytes in addition to the header.
|
|
* when a ping message has been received (header
|
|
* only), NbOfReceivedBytes = 0 */
|
|
uint8_t StartSending = 0x0; /* Set when a transmission is triggered by the user */
|
|
uint32_t TxSize = 0x0; /* Number of bytes to transmit in addition to the header.
|
|
* In case of ping operation (only the header sent),
|
|
* TxSize = 0 */
|
|
uint8_t InitiatorAddress1 = 0x0; /* Transmitter logical address 1 */
|
|
uint8_t InitiatorAddress2 = 0x0; /* Transmitter logical address 2 (if applicable) */
|
|
uint8_t MyFollowerAddress1 = 0x0; /* Destination logical address 1 */
|
|
uint8_t MyFollowerAddress2 = 0x0; /* Destination logical address 2 (if applicable) */
|
|
uint8_t DestinationAddress = 0x0; /* Destination logical address, set on the
|
|
* fly based on the button pushed by the user */
|
|
__IO uint8_t TxStatus = 0;
|
|
|
|
CEC_HandleTypeDef hcec;
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
void SystemClock_Config(void);
|
|
static void CEC_Config(CEC_HandleTypeDef *hcec);
|
|
static void CEC_FlushRxBuffer(void);
|
|
/* Private functions ---------------------------------------------------------*/
|
|
|
|
/**
|
|
* @brief Main program
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
int main(void)
|
|
{
|
|
/* This sample code shows how to use STM32F0xx CEC HAL API to transmit and
|
|
* receive data. The device is set in waiting to receive mode and sends
|
|
* messages when the evaluation board buttons are pushed by the user */
|
|
|
|
/* STM32F0xx HAL library initialization:
|
|
- Configure the Flash prefetch
|
|
- Systick timer is configured by default as source of time base, but user
|
|
can eventually implement his proper time base source (a general purpose
|
|
timer for example or other time source), keeping in mind that Time base
|
|
duration should be kept 1ms since PPP_TIMEOUT_VALUEs are defined and
|
|
handled in milliseconds basis.
|
|
- Low Level Initialization
|
|
*/
|
|
HAL_Init();
|
|
|
|
/* Configure the system clock to 48 MHz */
|
|
SystemClock_Config();
|
|
|
|
/* -1- Initialize LEDs mounted on EVAL board */
|
|
/* Configure LED1, LED2, LED3 and LED4 */
|
|
BSP_LED_Init(LED1);
|
|
BSP_LED_Init(LED2);
|
|
BSP_LED_Init(LED3);
|
|
BSP_LED_Init(LED4);
|
|
|
|
/* -2- Configure Tamper push-button in Interrupt mode */
|
|
/* button-triggered interruptions initialization */
|
|
BSP_PB_Init(BUTTON_TAMPER,BUTTON_MODE_EXTI);
|
|
|
|
/* -3- Configure Joystick Sel push-button in Interrupt mode */
|
|
BSP_JOY_Init(JOY_MODE_EXTI);
|
|
|
|
/* CEC device initialization */
|
|
|
|
#if defined (DEVICE_1)
|
|
/* Device 1:
|
|
* a single logical address ... */
|
|
InitiatorAddress1 = DEVICE_ADDRESS_1;
|
|
/* ... and two different follower addresses */
|
|
MyFollowerAddress1 = DEVICE_ADDRESS_2;
|
|
MyFollowerAddress2 = DEVICE_ADDRESS_3;
|
|
#elif defined (DEVICE_2)
|
|
/* Device 2:
|
|
* two different logical addresses ... */
|
|
InitiatorAddress1 = DEVICE_ADDRESS_2;
|
|
InitiatorAddress2 = DEVICE_ADDRESS_3;
|
|
/* ... and a single follower address */
|
|
MyFollowerAddress1 = DEVICE_ADDRESS_1;
|
|
#endif /* DEVICE_1 */
|
|
|
|
/* -4- CEC configuration (transfer will take place in Interrupt mode) */
|
|
hcec.Instance = CEC;
|
|
/* Deinitialize CEC to reinitialize from scratch */
|
|
HAL_CEC_DeInit(&hcec);
|
|
/* IP configuration */
|
|
CEC_Config(&hcec);
|
|
|
|
|
|
/* -5- CEC transfer general variables initialization */
|
|
ReceivedFrame = 0;
|
|
StartSending = 0;
|
|
NbOfReceivedBytes = 0;
|
|
CEC_FlushRxBuffer();
|
|
|
|
while (1)
|
|
{
|
|
/* if no reception has occurred and no error has been detected,
|
|
transmit a message if the user has pushed a button */
|
|
while( (StartSending == 1) && (ReceivedFrame == 0))
|
|
{
|
|
HAL_CEC_Transmit_IT(&hcec,InitiatorAddress1 ,DestinationAddress, (uint8_t *)&Tab_Tx, TxSize);
|
|
/* loop until TX ends or TX error reported */
|
|
while (TxStatus != 1);
|
|
StartSending = 0;
|
|
TxStatus = 0;
|
|
}
|
|
|
|
/* if a frame has been received */
|
|
if (ReceivedFrame == 1)
|
|
{
|
|
/* Test on the Destination Logical Address
|
|
* (code applicable whatever the device):
|
|
* if Receiver has address 0x01 */
|
|
if ((Tab_Rx[0]&0x0F) == 0x01)
|
|
{
|
|
/* Turn on LED1 */
|
|
BSP_LED_On(LED1);
|
|
/* Turn on LED4 */
|
|
BSP_LED_On(LED4);
|
|
/* Turn off LED3 */
|
|
BSP_LED_Off(LED3);
|
|
}
|
|
/* if Receiver has address 0x03 */
|
|
else if ((Tab_Rx[0]&0x0F) == 0x03)
|
|
{
|
|
/* Turn on LED1 */
|
|
BSP_LED_On(LED1);
|
|
/* Turn off LED4 */
|
|
BSP_LED_Off(LED4);
|
|
/* Turn off LED3 */
|
|
BSP_LED_Off(LED3);
|
|
}
|
|
/* if Receiver has address 0x05 */
|
|
else if ((Tab_Rx[0]&0x0F) == 0x05)
|
|
{
|
|
/* Turn on LED4 */
|
|
BSP_LED_On(LED4);
|
|
/* Turn off LED1 */
|
|
BSP_LED_Off(LED1);
|
|
/* Turn off LED3 */
|
|
BSP_LED_Off(LED3);
|
|
}
|
|
/* if Broadcast message */
|
|
else if ((Tab_Rx[0]&0x0F) == 0x0F)
|
|
{
|
|
/* Turn off all LEDs */
|
|
BSP_LED_Off(LED1);
|
|
BSP_LED_Off(LED2);
|
|
BSP_LED_Off(LED3);
|
|
BSP_LED_Off(LED4);
|
|
}
|
|
ReceivedFrame = 0;
|
|
CEC_FlushRxBuffer();
|
|
}
|
|
else if (ReceivedFrame == 2) /* means CEC error detected */
|
|
{
|
|
/* Turn on LED3 */
|
|
BSP_LED_On(LED3);
|
|
ReceivedFrame = 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Configures the CEC peripheral.
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void CEC_Config(CEC_HandleTypeDef *hcec)
|
|
{
|
|
/* CEC configuration parameters */
|
|
#if defined (DEVICE_1)
|
|
hcec->Init.OwnAddress = CEC_OWN_ADDRESS_1;
|
|
#elif defined (DEVICE_2)
|
|
hcec->Init.OwnAddress = CEC_OWN_ADDRESS_3|CEC_OWN_ADDRESS_5;
|
|
#endif
|
|
|
|
hcec->Init.SignalFreeTime = CEC_DEFAULT_SFT;
|
|
hcec->Init.Tolerance = CEC_STANDARD_TOLERANCE;
|
|
hcec->Init.BRERxStop = CEC_NO_RX_STOP_ON_BRE;
|
|
hcec->Init.BREErrorBitGen = CEC_BRE_ERRORBIT_NO_GENERATION;
|
|
hcec->Init.LBPEErrorBitGen = CEC_LBPE_ERRORBIT_NO_GENERATION;
|
|
hcec->Init.BroadcastMsgNoErrorBitGen = CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION;
|
|
hcec->Init.SignalFreeTimeOption = CEC_SFT_START_ON_TXSOM;
|
|
hcec->Init.ListenMode = CEC_REDUCED_LISTENING_MODE;
|
|
hcec->Init.RxBuffer = Tab_Rx;
|
|
|
|
HAL_CEC_Init(hcec);
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* @brief Tx Transfer completed callback
|
|
* @param hcec: CEC handle
|
|
* @retval None
|
|
*/
|
|
void HAL_CEC_TxCpltCallback(CEC_HandleTypeDef *hcec)
|
|
{
|
|
TxStatus = 1;
|
|
}
|
|
|
|
|
|
/**
|
|
* @brief Rx Transfer completed callback
|
|
* @param hcec: CEC handle
|
|
* @retval None
|
|
*/
|
|
void HAL_CEC_RxCpltCallback(CEC_HandleTypeDef *hcec, uint32_t RxFrameSize)
|
|
{
|
|
ReceivedFrame = 1;
|
|
}
|
|
|
|
/**
|
|
* @brief CEC error callbacks
|
|
* @param hcec: CEC handle
|
|
* @retval None
|
|
*/
|
|
void HAL_CEC_ErrorCallback(CEC_HandleTypeDef *hcec)
|
|
{
|
|
ReceivedFrame = 2;
|
|
}
|
|
|
|
/**
|
|
* @brief Reset CEC reception buffer
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void CEC_FlushRxBuffer(void)
|
|
{
|
|
uint32_t cpt;
|
|
|
|
for (cpt = CEC_MAX_PAYLOAD; cpt > 0; cpt--)
|
|
{
|
|
Tab_Rx[cpt-1] = 0;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* @brief EXTI line detection callbacks
|
|
* @param GPIO_Pin: Specifies the pins connected EXTI line
|
|
* @retval None
|
|
*/
|
|
void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
|
|
{
|
|
|
|
if(GPIO_Pin == TAMPER_BUTTON_PIN)
|
|
{
|
|
/* Toggle GREEN LED1 */
|
|
BSP_LED_Toggle(LED1);
|
|
DestinationAddress = MyFollowerAddress1;
|
|
TxSize = 0x0; /* no payload, ping only */
|
|
StartSending = 1;
|
|
}
|
|
|
|
if(GPIO_Pin == DOWN_JOY_PIN)
|
|
{
|
|
/* Toggle BLUE LED4 */
|
|
BSP_LED_Toggle(LED4);
|
|
#if defined (DEVICE_1)
|
|
DestinationAddress = MyFollowerAddress2;
|
|
#elif defined (DEVICE_2)
|
|
DestinationAddress = MyFollowerAddress1;
|
|
#endif /* DEVICE_1 */
|
|
TxSize = 0x0; /* no payload, ping only */
|
|
StartSending = 1;
|
|
}
|
|
if(GPIO_Pin == SEL_JOY_PIN)
|
|
{
|
|
/* Toggle ORANGE LED2 */
|
|
BSP_LED_Toggle(LED2);
|
|
DestinationAddress = 0xF; /* broadcast message indicator */
|
|
TxSize = 0x0; /* no payload, ping only */
|
|
StartSending = 1;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief System Clock Configuration
|
|
* The system Clock is configured as follow :
|
|
* System Clock source = PLL (HSE)
|
|
* SYSCLK(Hz) = 48000000
|
|
* HCLK(Hz) = 48000000
|
|
* AHB Prescaler = 1
|
|
* APB1 Prescaler = 1
|
|
* HSE Frequency(Hz) = 8000000
|
|
* PREDIV = 1
|
|
* PLLMUL = 6
|
|
* Flash Latency(WS) = 1
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
void SystemClock_Config(void)
|
|
{
|
|
RCC_ClkInitTypeDef RCC_ClkInitStruct;
|
|
RCC_OscInitTypeDef RCC_OscInitStruct;
|
|
|
|
/* Enable HSE Oscillator and Activate PLL with HSE as source */
|
|
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
|
|
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
|
|
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
|
|
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
|
|
RCC_OscInitStruct.PLL.PREDIV = RCC_PREDIV_DIV1;
|
|
RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL6;
|
|
if (HAL_RCC_OscConfig(&RCC_OscInitStruct)!= HAL_OK)
|
|
{
|
|
/* Initialization Error */
|
|
while(1);
|
|
}
|
|
|
|
/* Select PLL as system clock source and configure the HCLK, PCLK1 clocks dividers */
|
|
RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1);
|
|
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
|
|
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
|
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
|
|
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1)!= HAL_OK)
|
|
{
|
|
/* Initialization Error */
|
|
while(1);
|
|
}
|
|
}
|
|
|
|
|
|
#ifdef USE_FULL_ASSERT
|
|
/**
|
|
* @brief Reports the name of the source file and the source line number
|
|
* where the assert_param error has occurred.
|
|
* @param file: pointer to the source file name
|
|
* @param line: assert_param error line source number
|
|
* @retval None
|
|
*/
|
|
void assert_failed(uint8_t* file, uint32_t line)
|
|
{
|
|
/* User can add his own implementation to report the file name and line number,
|
|
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
|
|
|
|
/* Infinite loop */
|
|
while (1)
|
|
{
|
|
}
|
|
}
|
|
#endif
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|