I2C связи STM32F3, как я могу решить? - PullRequest
0 голосов
/ 03 мая 2018

Я хочу прочитать сенсорную активность с сенсорного экрана. Если я касаюсь, я хочу, чтобы светодиод мигал. Некоторые из моих определений в приведенном ниже коде, но в целом я хочу, чтобы моя активность была с i2c

Некоторые определения:

    uint8_t deviceaddr;
static uint32_t touch_i2c_read(uint8_t DeviceAddr, uint8_t RegAddr, uint8_t *pBuffer, uint16_t len);
static const int I2C_TIMEOUT = 65536;
unsigned char i2c_buffer[256];
uint32_t res;

This is my i2c read code:

    static uint32_t touch_i2c_read(uint8_t DeviceAddr, uint8_t RegAddr, uint8_t *pBuffer, uint16_t len)
{ //uint8_t deviceaddr ,0x00,(uint8_t *)&buf, sizeof(buf)

  uint32_t timeout = I2C_TIMEOUT;
  while (I2C_GetFlagStatus(I2C1, I2C_ISR_BUSY) != RESET)
  {
    if ((timeout--) == 0)
      return 0;
  }
  I2C_TransferHandling(I2C1, DeviceAddr << 1, 1, I2C_SoftEnd_Mode, I2C_Generate_Start_Write);

  /* !!! Wait until TXIS flag is set !!! */
  timeout = I2C_TIMEOUT;
  while (I2C_GetFlagStatus(I2C1, I2C_ISR_TXIS) == RESET)
  {
    if ((timeout--) == 0)
      return 0;
  }
}

Это мои настройки

void configure_interrupt_pins()
{

  GPIO_InitTypeDef GPIO_InitStruct;
  EXTI_InitTypeDef EXTI_InitStruct;
  NVIC_InitTypeDef NVIC_InitStruct;

  GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
  GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStruct.GPIO_Pin = GPIO_Pin_1;
  GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_UP;
  GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOB, &GPIO_InitStruct);

  /*ENABLE CLOCK FOR GPIOX*/
  RCC_APB1PeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);
  // ENABLE CLOCK FOR SYSCFG
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE);
  //SET PIN AS INPUT
  // init_pin(EX_NCVIC_PORT, EX_NCVIC_Pin, GPIO_MODE_INPUT, GPIO_Speed_50MHz, GPIO_OType_PP, GPIO_PuPd_UP);
  //TELL THE SYSTEM THAT YOU WILL USE PXX FOR EXTI_LineX
  SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOx, EXTI_PinSourcex);

  //CONFIGIRATION of exti

  EXTI_InitStruct.EXTI_Line = EXTI_Linex;                     //pxx connect to line x
  EXTI_InitStruct.EXTI_LineCmd = ENABLE;                      //enable interrupt
  EXTI_InitStruct.EXTI_Mode = EXTI_Mode_Interrupt;            //interrupt mode
  EXTI_InitStruct.EXTI_Trigger = EXTI_Trigger_Rising_Falling; //triggers on rising and failing edge
  EXTI_Init(&EXTI_InitStruct);                                //add to exti

  //CONFIGURATION of nvic

  NVIC_InitStruct.NVIC_IRQChannel = EXTI0_IRQn;
  NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0x00;
  NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0x00;
  NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStruct);
}

Это мое прерывание

  void EXTI0_IRQHandler(void)
{
  if (EXTI_GetITStatus((EXTI_Line0) != RESET))
  {
    res = touch_i2c_read(0x42, 0x00, i2c_buffer, 22);
    printf("deneme");
    if (!res)
    {
      GPIO_SetBits(GPIOE, GPIO_Pin_13);
    }

    else
    {
      GPIO_SetBits(GPIOE, GPIO_Pin_13);
    }
    EXTI_ClearITPendingBit(EXTI_Line0);
  }
}

Но мой код не работает. Stm32 не понимает сенсорную деятельность, как я могу решить эту проблему.

Изменить я меняю строку 1 каждые внешние прерывания, но у меня есть значение res 0, как я могу это исправить, оно должно отличаться 0

Ответы [ 2 ]

0 голосов
/ 07 мая 2018

Я решил эту ошибку. У меня не было сигналов pb7 и pb6, поэтому я изменил коды, как показано ниже:

    // enable APB1 peripheral clock for I2C1
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE);
  // enable clock for SCL and SDA pins
  RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);

А потом,

Адрес устройства FT6236 был неясным. это не включает в таблицу данных, поэтому я использовал отладку. Я нашел адрес устройства (0x32). И чем мой код работает успешно.

0 голосов
/ 04 мая 2018

Использование цикла while () в прерывании вызовет проблемы, потому что контроллер никогда не выйдет из цикла. Попробуйте использовать функцию чтения i2c в main () (другими словами, в контексте без прерываний) и посмотрите, работает ли он там.

...