Add i2c definition for stm32.
authorasterix <asterix@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 29 Jun 2010 10:17:48 +0000 (10:17 +0000)
committerasterix <asterix@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 29 Jun 2010 10:17:48 +0000 (10:17 +0000)
git-svn-id: https://src.develer.com/svnoss/bertos/trunk@3967 38d2e660-2303-0410-9eaa-f027e97ec537

bertos/cpu/cortex-m3/io/stm32.h
bertos/cpu/cortex-m3/io/stm32_i2c.h [new file with mode: 0644]

index adbf5423e73e43e9f53326f0503fd0473027d634..22cb76828f20b93b7b77b2b4517709e0bda3ec32 100644 (file)
@@ -46,6 +46,7 @@
 #include "stm32_ints.h"
 #include "stm32_uart.h"
 #include "stm32_adc.h"
+#include "stm32_i2c.h"
 
 #define GPIO_USART1_TX_PIN     BV(9)
 #define GPIO_USART1_RX_PIN     BV(10)
diff --git a/bertos/cpu/cortex-m3/io/stm32_i2c.h b/bertos/cpu/cortex-m3/io/stm32_i2c.h
new file mode 100644 (file)
index 0000000..74be9e5
--- /dev/null
@@ -0,0 +1,269 @@
+/**
+ * \file
+ * <!--
+ * This file is part of BeRTOS.
+ *
+ * Bertos is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ * As a special exception, you may use this file as part of a free software
+ * library without restriction.  Specifically, if other files instantiate
+ * templates or use macros or inline functions from this file, or you compile
+ * this file and link it with other files to produce an executable, this
+ * file does not by itself cause the resulting executable to be covered by
+ * the GNU General Public License.  This exception does not however
+ * invalidate any other reasons why the executable file might be covered by
+ * the GNU General Public License.
+ *
+ * Copyright 2010 Develer S.r.l. (http://www.develer.com/)
+ *
+ * -->
+ *
+ * \brief STM32F103xx I2C definition.
+ */
+
+#ifndef STM32_I2C_H
+#define STM32_I2C_H
+
+#include <cpu/types.h>
+
+
+/* I2C_modes */
+#define I2C_MODE_I2C                    ((uint16_t)0x0000)
+#define I2C_MODE_SMBUSDEVICE            ((uint16_t)0x0002)
+#define I2C_MODE_SMBUSHOST              ((uint16_t)0x000A)
+
+/* I2C_duty_cycle_in_fast_mode */
+#define I2C_DUTYCYCLE_16_9              ((uint16_t)0x4000)
+#define I2C_DUTYCYCLE_2                 ((uint16_t)0xBFFF)
+
+/* I2C_cknowledgementy */
+#define I2C_ACK_ENABLE                  ((uint16_t)0x0400)
+#define I2C_ACK_DISABLE                 ((uint16_t)0x0000)
+
+/* I2C_transfer_direction */
+#define  I2C_DIRECTION_TRANSMITTER      ((uint8_t)0x00)
+#define  I2C_DIRECTION_RECEIVER         ((uint8_t)0x01)
+
+/* I2C_acknowledged_address_defines  */
+#define I2C_ACKNOWLEDGEDADDRESS_7BIT    ((uint16_t)0x4000)
+#define I2C_ACKNOWLEDGEDADDRESS_10BIT   ((uint16_t)0xC000)
+
+/* I2C_registers */
+#define I2C_REGISTER_CR1                ((uint8_t)0x00)
+#define I2C_REGISTER_CR2                ((uint8_t)0x04)
+#define I2C_REGISTER_OAR1               ((uint8_t)0x08)
+#define I2C_REGISTER_OAR2               ((uint8_t)0x0C)
+#define I2C_REGISTER_DR                 ((uint8_t)0x10)
+#define I2C_REGISTER_SR1                ((uint8_t)0x14)
+#define I2C_REGISTER_SR2                ((uint8_t)0x18)
+#define I2C_REGISTER_CCR                ((uint8_t)0x1C)
+#define I2C_REGISTER_TRISE              ((uint8_t)0x20)
+
+/* I2C_SMBus_alert_pin_level  */
+#define I2C_SMBUSALERT_LOW              ((uint16_t)0x2000)
+#define I2C_SMBUSALERT_HIGH             ((uint16_t)0xDFFF)
+
+/* I2C_PEC_position  */
+#define I2C_PECPOSITION_NEXT            ((uint16_t)0x0800)
+#define I2C_PECPOSITION_CURRENT         ((uint16_t)0xF7FF)
+
+/* I2C_interrupts_definition  */
+#define I2C_IT_BUF                      ((uint16_t)0x0400)
+#define I2C_IT_EVT                      ((uint16_t)0x0200)
+#define I2C_IT_ERR                      ((uint16_t)0x0100)
+
+/* I2C_interrupts_definition  */
+#define I2C_IT_SMBALERT                 ((uint32_t)0x01008000)
+#define I2C_IT_TIMEOUT                  ((uint32_t)0x01004000)
+#define I2C_IT_PECERR                   ((uint32_t)0x01001000)
+#define I2C_IT_OVR                      ((uint32_t)0x01000800)
+#define I2C_IT_AF                       ((uint32_t)0x01000400)
+#define I2C_IT_ARLO                     ((uint32_t)0x01000200)
+#define I2C_IT_BERR                     ((uint32_t)0x01000100)
+#define I2C_IT_TXE                      ((uint32_t)0x06000080)
+#define I2C_IT_RXNE                     ((uint32_t)0x06000040)
+#define I2C_IT_STOPF                    ((uint32_t)0x02000010)
+#define I2C_IT_ADD10                    ((uint32_t)0x02000008)
+#define I2C_IT_BTF                      ((uint32_t)0x02000004)
+#define I2C_IT_ADDR                     ((uint32_t)0x02000002)
+#define I2C_IT_SB                       ((uint32_t)0x02000001)
+
+/* SR2 register flags  */
+#define I2C_FLAG_DUALF                  ((uint32_t)0x00800000)
+#define I2C_FLAG_SMBHOST                ((uint32_t)0x00400000)
+#define I2C_FLAG_SMBDEFAULT             ((uint32_t)0x00200000)
+#define I2C_FLAG_GENCALL                ((uint32_t)0x00100000)
+#define I2C_FLAG_TRA                    ((uint32_t)0x00040000)
+#define I2C_FLAG_BUSY                   ((uint32_t)0x00020000)
+#define I2C_FLAG_MSL                    ((uint32_t)0x00010000)
+
+/* SR1 register flags  */
+#define I2C_FLAG_SMBALERT               ((uint32_t)0x10008000)
+#define I2C_FLAG_TIMEOUT                ((uint32_t)0x10004000)
+#define I2C_FLAG_PECERR                 ((uint32_t)0x10001000)
+#define I2C_FLAG_OVR                    ((uint32_t)0x10000800)
+#define I2C_FLAG_AF                     ((uint32_t)0x10000400)
+#define I2C_FLAG_ARLO                   ((uint32_t)0x10000200)
+#define I2C_FLAG_BERR                   ((uint32_t)0x10000100)
+#define I2C_FLAG_TXE                    ((uint32_t)0x10000080)
+#define I2C_FLAG_RXNE                   ((uint32_t)0x10000040)
+#define I2C_FLAG_STOPF                  ((uint32_t)0x10000010)
+#define I2C_FLAG_ADD10                  ((uint32_t)0x10000008)
+#define I2C_FLAG_BTF                    ((uint32_t)0x10000004)
+#define I2C_FLAG_ADDR                   ((uint32_t)0x10000002)
+#define I2C_FLAG_SB                     ((uint32_t)0x10000001)
+
+/* EV1  */
+#define  I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED       ((uint32_t)0x00060082) /* TRA, BUSY, TXE and ADDR flags */
+#define  I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED          ((uint32_t)0x00020002) /* BUSY and ADDR flags */
+#define  I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED ((uint32_t)0x00860080)  /* DUALF, TRA, BUSY and TXE flags */
+#define  I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED    ((uint32_t)0x00820000)  /* DUALF and BUSY flags */
+#define  I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED        ((uint32_t)0x00120000)  /* GENCALL and BUSY flags */
+
+/* EV2  */
+#define  I2C_EVENT_SLAVE_BYTE_RECEIVED                     ((uint32_t)0x00020040)  /* BUSY and RXNE flags */
+
+/* EV3 */
+#define  I2C_EVENT_SLAVE_BYTE_TRANSMITTED                  ((uint32_t)0x00060084)  /* TRA, BUSY, TXE and BTF flags */
+
+/* EV4 */
+#define  I2C_EVENT_SLAVE_STOP_DETECTED                     ((uint32_t)0x00000010)  /* STOPF flag */
+
+/* EV5 */
+#define  I2C_EVENT_MASTER_MODE_SELECT                      ((uint32_t)0x00030001)  /* BUSY, MSL and SB flag */
+
+/* EV6 */
+#define  I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED        ((uint32_t)0x00070082)  /* BUSY, MSL, ADDR, TXE and TRA flags */
+#define  I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED           ((uint32_t)0x00030002)  /* BUSY, MSL and ADDR flags */
+
+/* EV7 */
+#define  I2C_EVENT_MASTER_BYTE_RECEIVED                    ((uint32_t)0x00030040)  /* BUSY, MSL and RXNE flags */
+
+/* EV8 */
+#define I2C_EVENT_MASTER_BYTE_TRANSMITTING                 ((uint32_t)0x00070080) /* TRA, BUSY, MSL, TXE flags */
+
+/* EV8_2 */
+#define  I2C_EVENT_MASTER_BYTE_TRANSMITTED                 ((uint32_t)0x00070084)  /* TRA, BUSY, MSL, TXE and BTF flags */
+
+/* EV9 */
+#define  I2C_EVENT_MASTER_MODE_ADDRESS10                   ((uint32_t)0x00030008)  /* BUSY, MSL and ADD10 flags */
+
+/* EV3_2 */
+#define  I2C_EVENT_SLAVE_ACK_FAILURE                       ((uint32_t)0x00000400)  /* AF flag */
+
+
+
+/* I2C SPE mask */
+#define CR1_PE_SET              ((uint16_t)0x0001)
+#define CR1_PE_RESET            ((uint16_t)0xFFFE)
+
+/* I2C START mask */
+#define CR1_START_SET           ((uint16_t)0x0100)
+#define CR1_START_RESET         ((uint16_t)0xFEFF)
+
+/* I2C STOP mask */
+#define CR1_STOP_SET            ((uint16_t)0x0200)
+#define CR1_STOP_RESET          ((uint16_t)0xFDFF)
+
+/* I2C ACK mask */
+#define CR1_ACK_SET             ((uint16_t)0x0400)
+#define CR1_ACK_RESET           ((uint16_t)0xFBFF)
+
+/* I2C ENGC mask */
+#define CR1_ENGC_SET            ((uint16_t)0x0040)
+#define CR1_ENGC_RESET          ((uint16_t)0xFFBF)
+
+/* I2C SWRST mask */
+#define CR1_SWRST_SET           ((uint16_t)0x8000)
+#define CR1_SWRST_RESET         ((uint16_t)0x7FFF)
+
+/* I2C PEC mask */
+#define CR1_PEC_SET             ((uint16_t)0x1000)
+#define CR1_PEC_RESET           ((uint16_t)0xEFFF)
+
+/* I2C ENPEC mask */
+#define CR1_ENPEC_SET           ((uint16_t)0x0020)
+#define CR1_ENPEC_RESET         ((uint16_t)0xFFDF)
+
+/* I2C ENARP mask */
+#define CR1_ENARP_SET           ((uint16_t)0x0010)
+#define CR1_ENARP_RESET         ((uint16_t)0xFFEF)
+
+/* I2C NOSTRETCH mask */
+#define CR1_NOSTRETCH_SET       ((uint16_t)0x0080)
+#define CR1_NOSTRETCH_RESET     ((uint16_t)0xFF7F)
+
+/* I2C registers Masks */
+#define CR1_CLEAR_MASK          ((uint16_t)0xFBF5)
+
+/* I2C DMAEN mask */
+#define CR2_DMAEN_SET           ((uint16_t)0x0800)
+#define CR2_DMAEN_RESET         ((uint16_t)0xF7FF)
+
+/* I2C LAST mask */
+#define CR2_LAST_SET            ((uint16_t)0x1000)
+#define CR2_LAST_RESET          ((uint16_t)0xEFFF)
+
+/* I2C FREQ mask */
+#define CR2_FREQ_RESET          ((uint16_t)0xFFC0)
+
+/* I2C ADD0 mask */
+#define OAR1_ADD0_SET           ((uint16_t)0x0001)
+#define OAR1_ADD0_RESET         ((uint16_t)0xFFFE)
+
+/* I2C ENDUAL mask */
+#define OAR2_ENDUAL_SET         ((uint16_t)0x0001)
+#define OAR2_ENDUAL_RESET       ((uint16_t)0xFFFE)
+
+/* I2C ADD2 mask */
+#define OAR2_ADD2_RESET         ((uint16_t)0xFF01)
+
+/* I2C F/S mask */
+#define CCR_FS_SET              ((uint16_t)0x8000)
+
+/* I2C CCR mask */
+#define CCR_CCR_SET             ((uint16_t)0x0FFF)
+
+/* I2C FLAG mask */
+#define FLAG_MASK               ((uint32_t)0x00FFFFFF)
+
+/* I2C Interrupt Enable mask */
+#define ITEN_MASK               ((uint32_t)0x07000000)
+
+
+struct stm32_i2c
+{
+       reg16_t CR1;
+       uint16_t  RESERVED0;
+       reg16_t CR2;
+       uint16_t  RESERVED1;
+       reg16_t OAR1;
+       uint16_t  RESERVED2;
+       reg16_t OAR2;
+       uint16_t  RESERVED3;
+       reg16_t DR;
+       uint16_t  RESERVED4;
+       reg16_t SR1;
+       uint16_t  RESERVED5;
+       reg16_t SR2;
+       uint16_t  RESERVED6;
+       reg16_t CCR;
+       uint16_t  RESERVED7;
+       reg16_t TRISE;
+       uint16_t  RESERVED8;
+       reg16_t DR;
+};
+
+#endif /* STM32_I2C_H */