stm32f4にi2cスレーブレシーバー割り込みサービスルーチンを実装しようとしています。これが私のスマートなコードです。
void I2C2_EV_IRQHandler()
{
switch (I2C_GetLastEvent(I2C2))
{
//The address sent by the master matches the own address of the peripheral
case I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED:
//The slave stretches SCL low until ADDR is
//cleared and DR filled with the data to be sent
I2C_ClearFlag(I2C2,I2C_FLAG_ADDR);
break;
//The application is expecting a data byte to be received
case I2C_EVENT_SLAVE_BYTE_RECEIVED:
I2C_ReceiveData(I2C2);
break;
//The application is expecting the end of the communication
//Make sure that both ADDR and STOPF flags are cleared
//if both are found set.
case I2C_EVENT_SLAVE_STOP_DETECTED:
if(I2C_GetFlagStatus(I2C2,I2C_FLAG_ADDR) == SET)
I2C_ClearFlag(I2C2,I2C_FLAG_ADDR);
if(I2C_GetFlagStatus(I2C2,I2C_FLAG_STOPF) == SET)
I2C_ClearFlag(I2C2,I2C_FLAG_STOPF);
}
}
割り込みが呼び出され、I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHEDケースに入ります。現在、SCLは低くなっています。リファレンスマニュアルには、アドレスフラグをクリアすると、クロックが続行され、データが送信されると記載されています(ページ579-スレーブレシーバー)。私の意見では、データが到着すると割り込みが常に呼び出され、次の状態はI2C_EVENT_SLAVE_BYTE_RECEIVEDになります。
stmまたはgoogle経由で例を見つけることができません。誰かが私を助けたり、例を見せてくれますか?