📄 main.c
字号:
/******************** (C) COPYRIGHT 2006 STMicroelectronics ********************
* File Name : main.c
* Author : MCD Application Team
* Date First Issued : 03/10/2006
* Description : Main program body
********************************************************************************
* History:
* 07/17/2006 : V1.0
* 03/10/2006 : V0.1
********************************************************************************
* THE PRESENT SOFTWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME.
* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/
/* Includes ------------------------------------------------------------------*/
#include "75x_lib.h"
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
GPIO_InitTypeDef GPIO_InitStructure;
EIC_IRQInitTypeDef EIC_IRQInitStructure;
CAN_InitTypeDef CAN_Struct;
ErrorStatus OSC4MStartUpStatus;
enum {
LD2,
LD3,
LD4,
LD5
};
/* buffer for receive messages */
canmsg RxCanMsg;
/* used message object numbers */
enum {
CAN_TX_MSGOBJ = 0,
CAN_RX_MSGOBJ = 1
};
/* array of pre-defined transmit messages */
canmsg TxCanMsg[3] = {
{ CAN_STD_ID, 0x123, 4, { 0x01, 0x02, 0x04, 0x08 } },
{ CAN_STD_ID, 0x321, 4, { 0xAA, 0x55, 0xAA, 0x55 } },
{ CAN_EXT_ID, 0x12345678, 8, { 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17 } }
};
/* Private function prototypes -----------------------------------------------*/
/* Private functions ---------------------------------------------------------*/
void delay(u32 XTime)
{
u32 j;
for(j=0;j<XTime;j++);
}
void System_Setup(void)
{
/* MRCC system reset(for debug purpose) */
MRCC_DeInit();
/* Wait for OSC4M start-up */
OSC4MStartUpStatus = MRCC_WaitForOSC4MStartUp();
if(OSC4MStartUpStatus == SUCCESS)
{
/* HCLK equal to 32MHz */
MRCC_HCLKConfig(MRCC_CKSYS_Div2);
/* CKTIM equal to 16MHz */
MRCC_CKTIMConfig(MRCC_HCLK_Div2);
/* PCLK equal to 8MHz */
MRCC_PCLKConfig(MRCC_CKTIM_Div2);
/* CKSYS equal to 64MHz */
MRCC_CKSYSConfig(MRCC_CKSYS_OSC4MPLL, MRCC_PLL_Mul_16);
}
/* GPIO pins optimized for 3V3 operation */
MRCC_IOVoltageRangeConfig(MRCC_IOVoltageRange_3V3);
/* GPIO and CAN clock enabling */
MRCC_PeripheralClockConfig(MRCC_Peripheral_GPIO | MRCC_Peripheral_CAN, ENABLE);
}
void IO_Init(void)
{
GPIO_DeInit(GPIO0);
GPIO_DeInit(GPIO1);
GPIO_DeInit(GPIO2);
/* set CAN TX and CAN RX */
GPIO_StructInit(&GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_15;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_WriteBit(GPIO0, GPIO_Pin_15, Bit_SET);/* to avoid falling edge on this IO */
GPIO_Init(GPIO0, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIO0, &GPIO_InitStructure);
/* set IO used for the LEDs */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIO1, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_16;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIO0, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_18 | GPIO_Pin_19 ;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIO2, &GPIO_InitStructure);
GPIO_WriteBit(GPIO1, GPIO_Pin_1, Bit_SET);
GPIO_WriteBit(GPIO0, GPIO_Pin_16, Bit_SET);
GPIO_Write(GPIO2,0x000C0000);
}
void LED_ON(u8 LED)
{
switch (LED)
{
case LD2: GPIO_WriteBit(GPIO1, GPIO_Pin_1, Bit_RESET); break;
case LD3: GPIO_WriteBit(GPIO0, GPIO_Pin_16, Bit_RESET); break;
case LD4: GPIO_WriteBit(GPIO2, GPIO_Pin_18, Bit_RESET); break;
case LD5: GPIO_WriteBit(GPIO2, GPIO_Pin_19, Bit_RESET); break;
default:;
}
}
void LED_OFF(u8 LED)
{
switch (LED)
{
case LD2: GPIO_WriteBit(GPIO1, GPIO_Pin_1, Bit_SET); break;
case LD3: GPIO_WriteBit(GPIO0, GPIO_Pin_16, Bit_SET); break;
case LD4: GPIO_WriteBit(GPIO2, GPIO_Pin_18, Bit_SET); break;
case LD5: GPIO_WriteBit(GPIO2, GPIO_Pin_19, Bit_SET); break;
default:;
}
}
void CAN_Com_LoopBack(void)
{
/* initialize the CAN at a standard bitrate, interrupts disabled */
CAN_Struct.CAN_ConfigParameters=0x0;
CAN_Struct.CAN_Bitrate=CAN_BITRATE_1M;
CAN_Init(&CAN_Struct);
/* switch into Loopback+Silent mode (self-test) */
CAN_EnterTestMode(CAN_TESTR_LBACK | CAN_TESTR_SILENT);
/* configure the message objects */
CAN_InvalidateAllMsgObj();
CAN_SetTxMsgObj(CAN_TX_MSGOBJ, CAN_STD_ID);
CAN_SetRxMsgObj(CAN_RX_MSGOBJ, CAN_STD_ID, 0, CAN_LAST_STD_ID, TRUE);
/* Send the pre-defined answer */
CAN_SendMessage(CAN_TX_MSGOBJ, &TxCanMsg[1]);
/* wait until end of transmission */
CAN_WaitEndOfTx();
/* message sent */
LED_ON(LD2);
/* wait for reception of a data frame */
while (!CAN_ReceiveMessage(CAN_RX_MSGOBJ, FALSE, &RxCanMsg))
{
/*Add Timer*/
}
/* Test Received Msg */
if((RxCanMsg.IdType == CAN_STD_ID)&&(RxCanMsg.Id == 0x321)&&(RxCanMsg.Dlc == 4)
&&(RxCanMsg.Data[0]==0xAA)&&(RxCanMsg.Data[1]==0x55)&&(RxCanMsg.Data[2]==0xAA)&&(RxCanMsg.Data[3]==0x55)){
/*Received Msg OK*/
LED_ON(LD3);
} else {
/*Received Msg KO*/
LED_OFF(LD2);
}
/* release the message objects */
CAN_ReleaseTxMessage(CAN_TX_MSGOBJ);
CAN_ReleaseRxMessage(CAN_RX_MSGOBJ);
/* switch back into Normal mode */
CAN_LeaveTestMode();
}
void CAN_Com_LoopBack_IRQ(void)
{
/* initialize the interrupt controller */
EIC_DeInit();
EIC_IRQInitStructure.EIC_IRQChannel=CAN_IRQChannel;
EIC_IRQInitStructure.EIC_IRQChannelPriority=1;
EIC_IRQInitStructure.EIC_IRQChannelCmd=ENABLE;
EIC_IRQInit(&EIC_IRQInitStructure);
/* initialize the CAN at a standard bitrate, interrupts enabled */
CAN_Struct.CAN_ConfigParameters=CAN_CR_IE;
CAN_Struct.CAN_Bitrate=CAN_BITRATE_100K;
CAN_Init(&CAN_Struct);
/* switch into Loopback+Silent mode (self-test) */
CAN_EnterTestMode(CAN_TESTR_LBACK | CAN_TESTR_SILENT);
/* configure the message objects */
CAN_InvalidateAllMsgObj();
CAN_SetTxMsgObj(CAN_TX_MSGOBJ, CAN_EXT_ID);
CAN_SetRxMsgObj(CAN_RX_MSGOBJ, CAN_EXT_ID, 0, CAN_LAST_EXT_ID, TRUE);
/* enable global interrupt */
EIC_IRQCmd(ENABLE);
/* Send the pre-defined frame */
CAN_SendMessage(CAN_TX_MSGOBJ, &TxCanMsg[2]);
/* wait until end of transmission */
CAN_WaitEndOfTx();
/* Message Sent */
LED_ON(LD4);
/* reception and release are done in the interrupt handler */
/* delay to add when the reception occurs */
delay(0xFFFF);
/* Test Received Msg */
if((RxCanMsg.IdType == CAN_EXT_ID)&&(RxCanMsg.Id == 0x12345678)&&(RxCanMsg.Dlc == 8)
&&(RxCanMsg.Data[0]==0x10)&&(RxCanMsg.Data[1]==0x11)&&(RxCanMsg.Data[2]==0x12)&&(RxCanMsg.Data[3]==0x13)
&&(RxCanMsg.Data[4]==0x14)&&(RxCanMsg.Data[5]==0x15)&&(RxCanMsg.Data[6]==0x16)&&(RxCanMsg.Data[7]==0x17)){
/*Received Msg OK*/
LED_ON(LD5);
} else {
/*Received Msg KO*/
LED_OFF(LD4);
}
/* switch back into Normal mode */
CAN_LeaveTestMode();
/* disable interrupts globally */
EIC_IRQCmd(DISABLE);
}
void main()
{
#ifdef DEBUG
debug();
#endif
/* System configuration */
System_Setup(); /* set CAN input clock at 8MHz */
IO_Init();
/* CAN tests */
CAN_Com_LoopBack();/* send and receive some frame */
CAN_Com_LoopBack_IRQ();/* send and receive some frame, received in 75x_it.c */
/* LD2, LD3, LD4 and LD5 should be lit */
while(1);
}
/******************* (C) COPYRIGHT 2006 STMicroelectronics *****END OF FILE****/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -