paparazzi-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[paparazzi-commits] [4810]


From: antoine drouin
Subject: [paparazzi-commits] [4810]
Date: Sun, 18 Apr 2010 23:31:35 +0000

Revision: 4810
          http://svn.sv.gnu.org/viewvc/?view=rev&root=paparazzi&revision=4810
Author:   poine
Date:     2010-04-18 23:31:35 +0000 (Sun, 18 Apr 2010)
Log Message:
-----------


Modified Paths:
--------------
    paparazzi3/trunk/sw/airborne/stm32/i2c_hw.h

Added Paths:
-----------
    paparazzi3/trunk/sw/airborne/stm32/i2c_hw.c

Added: paparazzi3/trunk/sw/airborne/stm32/i2c_hw.c
===================================================================
--- paparazzi3/trunk/sw/airborne/stm32/i2c_hw.c                         (rev 0)
+++ paparazzi3/trunk/sw/airborne/stm32/i2c_hw.c 2010-04-18 23:31:35 UTC (rev 
4810)
@@ -0,0 +1,146 @@
+#include "i2c.h"
+
+#include <stm32/rcc.h>
+#include <stm32/gpio.h>
+#include <stm32/flash.h>
+#include <stm32/misc.h>
+
+#include "led.h"
+
+#ifdef USE_I2C1
+
+#define I2C_TRANSMITTER             0x00
+#define I2C_RECEIVER                0x01
+static const uint8_t i2c2_direction = I2C_TRANSMITTER;
+
+void i2c1_hw_init(void) {
+
+  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
+  NVIC_InitTypeDef  NVIC_InitStructure;
+  
+  /* Configure and enable I2C1 event interrupt 
-------------------------------*/
+  NVIC_InitStructure.NVIC_IRQChannel = I2C1_EV_IRQn;
+  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
+  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
+  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
+  NVIC_Init(&NVIC_InitStructure);
+
+  /* Configure and enable I2C1 err interrupt -------------------------------*/
+  NVIC_InitStructure.NVIC_IRQChannel = I2C1_ER_IRQn;
+  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
+  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
+  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
+  NVIC_Init(&NVIC_InitStructure);
+  
+  /* Enable peripheral clocks 
--------------------------------------------------*/
+  /* Enable I2C1 clock */
+  RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE);
+  /* Enable GPIOB clock */
+  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
+
+  /* Configure I2C1 pins: SCL and SDA 
------------------------------------------*/
+  GPIO_InitTypeDef GPIO_InitStructure;
+  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_6 | GPIO_Pin_7;
+  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
+  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_OD;
+  GPIO_Init(GPIOB, &GPIO_InitStructure);
+
+  /* I2C configuration 
----------------------------------------------------------*/
+  I2C_InitTypeDef  I2C_InitStructure; 
+  I2C_InitStructure.I2C_Mode = I2C_Mode_I2C;
+  I2C_InitStructure.I2C_DutyCycle = I2C_DutyCycle_2;
+  I2C_InitStructure.I2C_OwnAddress1 = 0x02;
+  I2C_InitStructure.I2C_Ack = I2C_Ack_Enable;
+  //  I2C_InitStructure.I2C_Ack = I2C_Ack_Disable;
+  I2C_InitStructure.I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
+  I2C_InitStructure.I2C_ClockSpeed = 200000;
+  
+  /* I2C Peripheral Enable */
+  I2C_Cmd(I2C1, ENABLE);
+  /* Apply I2C configuration after enabling it */
+  I2C_Init(I2C1, &I2C_InitStructure);
+
+  /* Enable I2C1 event, buffer and error interrupts */
+  I2C_ITConfig(I2C1, I2C_IT_EVT, ENABLE);
+  //  I2C_ITConfig(I2C1, I2C_IT_EVT | I2C_IT_ERR, ENABLE);
+  //  I2C_ITConfig(I2C1, I2C_IT_EVT, ENABLE);
+
+}
+
+
+void i2c1_ev_irq_handler(void) {
+  switch (I2C_GetLastEvent(I2C1)) {
+  case I2C_EVENT_MASTER_MODE_SELECT:                 /* EV5 */
+    if(i2c2_direction == I2C_TRANSMITTER) {
+      /* Master Transmitter : Send slave Address for write */
+      I2C_Send7bitAddress(I2C1, (i2c1_slave_addr&0xFE), 
I2C_Direction_Transmitter);
+    }
+    else {
+      /* Master Receiver : Send slave Address for read */
+      I2C_Send7bitAddress(I2C1, (i2c1_slave_addr&0xFE), 
I2C_Direction_Receiver);
+    }
+    break;
+    
+    /* Master Transmitter --------------------------------------------------*/
+    /* Test on I2C1 EV6 and first EV8 and clear them */
+  case I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED:  
+    /* Send the first data */
+    I2C_ITConfig(I2C1, I2C_IT_BUF, ENABLE);
+    I2C_SendData(I2C1, i2c1_buf[0]);
+    i2c1_index = 1;
+    break;
+    
+    /* Test on I2C1 EV8 and clear it */
+  case I2C_EVENT_MASTER_BYTE_TRANSMITTING:  /* Without BTF, EV8 */     
+    if(i2c1_index < i2c1_len_w) {
+      I2C_SendData(I2C1, i2c1_buf[i2c1_index]);
+      i2c1_index++;
+    }
+    else {
+      I2C_GenerateSTOP(I2C1, ENABLE);
+      I2C_ITConfig(I2C1, I2C_IT_BUF, DISABLE);
+    }
+    break;
+
+  case I2C_EVENT_MASTER_BYTE_TRANSMITTED: /* With BTF EV8-2 */
+    if(i2c1_index >= i2c1_len_w) {
+      I2c1StopHandler();
+    }
+    break;
+
+    /* Master Receiver 
-------------------------------------------------------*/
+  case I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED:
+    //  if(Tx2BufferSize == 1) {
+      /* Disable I2C1 acknowledgement */
+    //      I2C_AcknowledgeConfig(I2C1, DISABLE);
+      /* Send I2C1 STOP Condition */
+    //      I2C_GenerateSTOP(I2C1, ENABLE);
+    //}
+    break;
+    
+    /* Test on I2C1 EV7 and clear it */
+  case I2C_EVENT_MASTER_BYTE_RECEIVED:
+    /* Store I2C1 received data */
+    //    I2C1_Buffer_Rx[Rx1_Idx++] = I2C_ReceiveData (I2C1);
+    /* Disable ACK and send I2C1 STOP condition before receiving the last data 
*/
+    //    if(Rx1_Idx == (Tx2BufferSize - 1)) {
+      /* Disable I2C1 acknowledgement */
+    //      I2C_AcknowledgeConfig(I2C1, DISABLE);
+      /* Send I2C1 STOP Condition */
+    //      I2C_GenerateSTOP(I2C1, ENABLE);
+    //  }
+    break;
+    
+  default:
+    break;
+  }
+}
+
+void i2c1_er_irq_handler(void) {
+  /* Check on I2C2 AF flag and clear it */
+  if (I2C_GetITStatus(I2C1, I2C_IT_AF))
+    I2C_ClearITPendingBit(I2C1, I2C_IT_AF);
+  LED_ON(4);
+}
+
+#endif /* USE_I2C1 */

Modified: paparazzi3/trunk/sw/airborne/stm32/i2c_hw.h
===================================================================
--- paparazzi3/trunk/sw/airborne/stm32/i2c_hw.h 2010-04-18 08:39:35 UTC (rev 
4809)
+++ paparazzi3/trunk/sw/airborne/stm32/i2c_hw.h 2010-04-18 23:31:35 UTC (rev 
4810)
@@ -40,6 +40,12 @@
 
 #define I2c1SendStart() { I2C_GenerateSTART(I2C1, ENABLE); }
 
+#ifdef I2C1_STOP_HANDLER
+#include I2C1_STOP_HANDLER_HEADER
+#define I2c1StopHandler() I2C1_STOP_HANDLER()
+#else 
+#define I2c1StopHandler() {}
+#endif /* I2C1_STOP_HANDLER */
 
 #endif /* USE_I2C1 */
 





reply via email to

[Prev in Thread] Current Thread [Next in Thread]