|
|
|
|
#include "SWM221.h"
|
|
|
|
|
#include "IOI2C_SLV.h"
|
|
|
|
|
|
|
|
|
|
#define SLV_ADDR 0x6C
|
|
|
|
|
|
|
|
|
|
char mst_txbuff[4] = {0x37, 0x55, 0xAA, 0x78};
|
|
|
|
|
char mst_rxbuff[4] = {0};
|
|
|
|
|
|
|
|
|
|
volatile uint32_t mst_txindx = 0;
|
|
|
|
|
volatile uint32_t mst_rxindx = 0;
|
|
|
|
|
|
|
|
|
|
#define MST_OP_TX 1
|
|
|
|
|
#define MST_OP_RX 2
|
|
|
|
|
volatile uint32_t mst_oper = 0;
|
|
|
|
|
|
|
|
|
|
#define MST_RES_SUCC 1
|
|
|
|
|
#define MST_RES_FAIL 2
|
|
|
|
|
volatile uint32_t mst_result = 0;
|
|
|
|
|
|
|
|
|
|
void SerialInit(void);
|
|
|
|
|
void I2C_Mst_Init(void);
|
|
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
|
{
|
|
|
|
|
uint32_t i;
|
|
|
|
|
|
|
|
|
|
SystemInit();
|
|
|
|
|
|
|
|
|
|
SerialInit();
|
|
|
|
|
|
|
|
|
|
IOI2C_SLV_Init();
|
|
|
|
|
|
|
|
|
|
I2C_Mst_Init();
|
|
|
|
|
|
|
|
|
|
NVIC_SetPriority(I2C0_IRQn, 3); // <20><><EFBFBD>ôӻ<C3B4><D3BB><EFBFBD><EFBFBD>ȼ<EFBFBD><C8BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ߣ<EFBFBD><DFA3><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD>ӻ<EFBFBD><D3BB><EFBFBD><EFBFBD>ܼ<EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݻ<EFBFBD><DDBB><EFBFBD>ӦNAK
|
|
|
|
|
|
|
|
|
|
while(1==1)
|
|
|
|
|
{
|
|
|
|
|
/*************************** Master Write ************************************/
|
|
|
|
|
mst_oper = MST_OP_TX;
|
|
|
|
|
mst_result = 0;
|
|
|
|
|
mst_txindx = 0;
|
|
|
|
|
|
|
|
|
|
I2C_Start(I2C0, (SLV_ADDR << 1) | 0, 0);
|
|
|
|
|
|
|
|
|
|
while(mst_result != MST_RES_SUCC)
|
|
|
|
|
{
|
|
|
|
|
if(mst_result == MST_RES_FAIL)
|
|
|
|
|
goto nextloop;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printf("Master Send %X %X %X %X\r\n", mst_txbuff[0], mst_txbuff[1], mst_txbuff[2], mst_txbuff[3]);
|
|
|
|
|
|
|
|
|
|
/********************************** Master Read *******************************/
|
|
|
|
|
mst_oper = MST_OP_RX;
|
|
|
|
|
mst_result = 0;
|
|
|
|
|
mst_rxindx = 0;
|
|
|
|
|
|
|
|
|
|
I2C_Start(I2C0, (SLV_ADDR << 1) | 1, 0);
|
|
|
|
|
|
|
|
|
|
while(mst_result != MST_RES_SUCC)
|
|
|
|
|
{
|
|
|
|
|
if(mst_result == MST_RES_FAIL)
|
|
|
|
|
goto nextloop;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printf("Master Read %X %X %X %X\r\n", mst_rxbuff[0], mst_rxbuff[1], mst_rxbuff[2], mst_rxbuff[3]);
|
|
|
|
|
|
|
|
|
|
if((mst_txbuff[0] == mst_rxbuff[0]) && (mst_txbuff[1] == mst_rxbuff[1]) && (mst_txbuff[2] == mst_rxbuff[2]) && (mst_txbuff[3] == mst_rxbuff[3]))
|
|
|
|
|
printf("Success\r\n");
|
|
|
|
|
else
|
|
|
|
|
printf("Fail\r\n");
|
|
|
|
|
|
|
|
|
|
nextloop:
|
|
|
|
|
I2C_Stop(I2C0, 1);
|
|
|
|
|
for(i = 0; i < SystemCoreClock/3; i++) __NOP();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void I2C_Mst_Init(void)
|
|
|
|
|
{
|
|
|
|
|
I2C_InitStructure I2C_initStruct;
|
|
|
|
|
|
|
|
|
|
PORT_Init(PORTA, PIN6, PORTA_PIN6_I2C0_SCL, 1); //GPIOA.6<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ΪI2C0 SCL<43><4C><EFBFBD><EFBFBD>
|
|
|
|
|
PORTA->OPEND |= (1 << PIN6); //<2F><>©<EFBFBD><C2A9><EFBFBD><EFBFBD>
|
|
|
|
|
PORTA->PULLU |= (1 << PIN6); //ʹ<><CAB9><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
PORT_Init(PORTA, PIN7, PORTA_PIN7_I2C0_SDA, 1); //GPIOA.7<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ΪI2C0 SDA<44><41><EFBFBD><EFBFBD>
|
|
|
|
|
PORTA->OPEND |= (1 << PIN7); //<2F><>©<EFBFBD><C2A9><EFBFBD><EFBFBD>
|
|
|
|
|
PORTA->PULLU |= (1 << PIN7); //ʹ<><CAB9><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
|
|
|
|
I2C_initStruct.Master = 1;
|
|
|
|
|
I2C_initStruct.MstClk = 100000;
|
|
|
|
|
I2C_initStruct.Addr10b = 0;
|
|
|
|
|
I2C_initStruct.TXEmptyIEn = 0;
|
|
|
|
|
I2C_initStruct.RXNotEmptyIEn = 0;
|
|
|
|
|
I2C_Init(I2C0, &I2C_initStruct);
|
|
|
|
|
|
|
|
|
|
I2C_INTEn(I2C0, I2C_IT_TX_DONE);
|
|
|
|
|
/* ע<>⣺<EFBFBD><E2A3BA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>в<EFBFBD><D0B2><EFBFBD>ʹ<EFBFBD><CAB9> RX_NOT_EMPTY <20>ж<EFBFBD><D0B6><EFBFBD><EFBFBD><EFBFBD> RX_DONE <20>жϣ<D0B6>
|
|
|
|
|
<EFBFBD><EFBFBD>Ϊ<EFBFBD><EFBFBD> RX_NOT_EMPTY <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ջ<EFBFBD>δ<EFBFBD><EFBFBD><EFBFBD>ɣ<EFBFBD>I2C0->MCR.RD <EFBFBD><EFBFBD>û<EFBFBD><EFBFBD><EFBFBD>㣬
|
|
|
|
|
<EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ж<EFBFBD>ִ<EFBFBD><EFBFBD> I2C_Read() <EFBFBD><EFBFBD><EFBFBD><EFBFBD> I2C0->MCR.RD λû<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ã<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
*/
|
|
|
|
|
I2C_INTEn(I2C0, I2C_IT_RX_DONE);
|
|
|
|
|
NVIC_EnableIRQ(I2C0_IRQn);
|
|
|
|
|
|
|
|
|
|
I2C_Open(I2C0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void I2C0_Handler(void)
|
|
|
|
|
{
|
|
|
|
|
if(I2C0->IF & I2C_IF_TXDONE_Msk) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
I2C0->IF = I2C_IF_TXDONE_Msk;
|
|
|
|
|
|
|
|
|
|
if(mst_oper == MST_OP_TX)
|
|
|
|
|
{
|
|
|
|
|
if(I2C_IsAck(I2C0))
|
|
|
|
|
{
|
|
|
|
|
if(mst_txindx < 4)
|
|
|
|
|
{
|
|
|
|
|
I2C_Write(I2C0, mst_txbuff[mst_txindx], 0);
|
|
|
|
|
|
|
|
|
|
mst_txindx++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
I2C_Stop(I2C0, 0);
|
|
|
|
|
|
|
|
|
|
mst_result = MST_RES_SUCC;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if(mst_txindx == 0)
|
|
|
|
|
printf("Slave send NACK for address\r\n");
|
|
|
|
|
else
|
|
|
|
|
printf("Slave send NACK for data\r\n");
|
|
|
|
|
|
|
|
|
|
mst_result = MST_RES_FAIL;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else // mst_oper == MST_OP_RX
|
|
|
|
|
{
|
|
|
|
|
if(I2C_IsAck(I2C0))
|
|
|
|
|
{
|
|
|
|
|
I2C_Read(I2C0, 1, 0);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
printf("Slave send NACK for address\r\n");
|
|
|
|
|
|
|
|
|
|
mst_result = MST_RES_FAIL;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if(I2C0->IF & I2C_IF_RXDONE_Msk) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
{
|
|
|
|
|
I2C0->IF = I2C_IF_RXDONE_Msk;
|
|
|
|
|
|
|
|
|
|
if(mst_rxindx < 4)
|
|
|
|
|
{
|
|
|
|
|
mst_rxbuff[mst_rxindx] = I2C0->RXDATA;
|
|
|
|
|
|
|
|
|
|
mst_rxindx++;
|
|
|
|
|
|
|
|
|
|
if(mst_rxindx < 3)
|
|
|
|
|
{
|
|
|
|
|
I2C_Read(I2C0, 1, 0);
|
|
|
|
|
}
|
|
|
|
|
else if(mst_rxindx < 4)
|
|
|
|
|
{
|
|
|
|
|
I2C_Read(I2C0, 0, 0);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
I2C_Stop(I2C0, 0);
|
|
|
|
|
|
|
|
|
|
mst_result = MST_RES_SUCC;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
uint32_t IOI2C_SLV_EmptyCallback(char *TxBuff)
|
|
|
|
|
{
|
|
|
|
|
uint32_t i = 0;
|
|
|
|
|
|
|
|
|
|
while(IOI2C_SLV_RxNotEmpty())
|
|
|
|
|
TxBuff[i++] = IOI2C_SLV_FetchByte();
|
|
|
|
|
|
|
|
|
|
return i;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SerialInit(void)
|
|
|
|
|
{
|
|
|
|
|
UART_InitStructure UART_initStruct;
|
|
|
|
|
|
|
|
|
|
PORT_Init(PORTA, PIN0, PORTA_PIN0_UART0_RX, 1); //GPIOA.0<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ΪUART0 RXD
|
|
|
|
|
PORT_Init(PORTA, PIN1, PORTA_PIN1_UART0_TX, 0); //GPIOA.1<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ΪUART0 TXD
|
|
|
|
|
|
|
|
|
|
UART_initStruct.Baudrate = 57600;
|
|
|
|
|
UART_initStruct.DataBits = UART_DATA_8BIT;
|
|
|
|
|
UART_initStruct.Parity = UART_PARITY_NONE;
|
|
|
|
|
UART_initStruct.StopBits = UART_STOP_1BIT;
|
|
|
|
|
UART_initStruct.RXThreshold = 3;
|
|
|
|
|
UART_initStruct.RXThresholdIEn = 0;
|
|
|
|
|
UART_initStruct.TXThreshold = 3;
|
|
|
|
|
UART_initStruct.TXThresholdIEn = 0;
|
|
|
|
|
UART_initStruct.TimeoutTime = 10;
|
|
|
|
|
UART_initStruct.TimeoutIEn = 0;
|
|
|
|
|
UART_Init(UART0, &UART_initStruct);
|
|
|
|
|
UART_Open(UART0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/******************************************************************************************************************************************
|
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: fputc()
|
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD>˵<EFBFBD><EFBFBD>: printf()ʹ<EFBFBD>ô˺<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʵ<EFBFBD>ʵĴ<EFBFBD><EFBFBD>ڴ<EFBFBD>ӡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
* <EFBFBD><EFBFBD> <EFBFBD><EFBFBD>: int ch Ҫ<EFBFBD><EFBFBD>ӡ<EFBFBD><EFBFBD><EFBFBD>ַ<EFBFBD>
|
|
|
|
|
* FILE *f <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
* <EFBFBD><EFBFBD> <EFBFBD><EFBFBD>: <EFBFBD><EFBFBD>
|
|
|
|
|
* ע<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <EFBFBD><EFBFBD>
|
|
|
|
|
******************************************************************************************************************************************/
|
|
|
|
|
int fputc(int ch, FILE *f)
|
|
|
|
|
{
|
|
|
|
|
UART_WriteByte(UART0, ch);
|
|
|
|
|
|
|
|
|
|
while(UART_IsTXBusy(UART0));
|
|
|
|
|
|
|
|
|
|
return ch;
|
|
|
|
|
}
|