

# MICROS 32 BITS

## STM – I2C

ROBINSON JIMENEZ MORENO



UNIVERSIDAD MILITAR  
NUEVA GRANADA



## INTRODUCCION: COMUNICACION SERIAL A 1 LINEA

### DHT11 Humidity & Temperature Sensor



DHT11 Temperature & Humidity Sensor features a temperature & humidity sensor complex with a calibrated digital signal output. By using the exclusive digital-signal-acquisition technique and temperature & humidity sensing technology, it ensures high reliability and excellent long-term stability. This sensor includes a resistive-type humidity measurement component and an NTC temperature measurement component, and connects to a high-performance 8-bit microcontroller, offering excellent quality, fast response, anti-interference ability and cost-effectiveness.

## 2. Technical Specifications:

### Overview:



| Item  | Measurement Range   | Humidity Accuracy | Temperature Accuracy | Resolution | Package          |
|-------|---------------------|-------------------|----------------------|------------|------------------|
| DHT11 | 20-90%RH<br>0-50 °C | ±5% RH            | ±2 °C                | 1          | 4 Pin Single Row |

## 4. Power and Pin

DHT11's power supply is 3-5.5V DC. When power is supplied to the sensor, do not send any instruction to the sensor in within one second in order to pass the unstable status. One capacitor valued 100nF can be added between VDD and GND for power filtering.

## 5. Communication Process: Serial Interface (Single-Wire Two-Way)

Single-bus data format is used for communication and synchronization between MCU and DHT11 sensor. One communication process is about 4ms.

Data consists of decimal and integral parts. A complete data transmission is **40bit**, and the sensor sends **higher data bit** first.

**Data format:** 8bit integral RH data + 8bit decimal RH data + 8bit integral T data + 8bit decimal T data + 8bit check sum. If the data transmission is right, the check-sum should be the last 8bit of "8bit integral RH data + 8bit decimal RH data + 8bit integral T data + 8bit decimal T data".

## 5.1 Overall Communication Process (Figure 2, below)

When MCU sends a start signal, DHT11 changes from the low-power-consumption mode to the running-mode, waiting for MCU completing the start signal. Once it is completed, DHT11 sends a response signal of 40-bit data that include the relative humidity and temperature information to MCU. Users can choose to collect (read) some data. Without the start signal from MCU, DHT11 will not give the response signal to MCU. Once data is collected, DHT11 will change to the low-power-consumption mode until it receives a start signal from MCU again.



## 5.2 MCU Sends out Start Signal to DHT (Figure 3, below)

Data Single-bus free status is at high voltage level. When the communication between MCU and DHT11 begins, the programme of MCU will set Data Single-bus voltage level from high to low and this process must take at least 18ms to ensure DHT's detection of MCU's signal, then MCU will pull up voltage and wait 20-40us for DHT's response.



When DHT is sending data to MCU, every bit of data begins with the 50us low-voltage-level and the length of the following high-voltage-level signal determines whether data bit is "0" or "1" (see Figures 4 and 5 below).





```
////////// Temper humedad/////////
#include "LibrLCD.h"
LibrLCD lib;
void LCD();
char dato[7]={'T','e','m','p',' ','=',' '};
char dato2[7]={'H','u','m','e',' ','=',' '};
char clear=0x01;
char LCD1L=0x80;
char LCD2L=0xC0;
int t,h,h1,h2,datos,ck=0;
```

Example 1: 40 data is received:

|                 |                |              |             |            |
|-----------------|----------------|--------------|-------------|------------|
| 0011 0101       | 0000 0000      | 0001 1000    | 0000 0000   | 0100 1101  |
| High humidity 8 | Low humidity 8 | High temp. 8 | Low temp. 8 | Parity bit |

Calculate:

0011 0101+0000 0000+0001 1000+0000 0000= 0100 1101

Received data is correct:

Humidity: 0011 0101=35H=53%RH

Temperature: 0001 1000=18H=24°C

```
int main(void){
    lib.cfglcd();
    lib.send_comando(clear);
    for (int i=0;i<50000;i++);
        SystemCoreClockUpdate();
        SysTick_Config(SystemCoreClock);
    RCC -> APB1ENR = 0X1;
    TIM2 -> CR1 = 0X1;
    TIM2 -> ARR = 30000;
    TIM2 -> PSC = 16;
    GPIOC->MODER =1;
    GPIOC->OSPEEDR =3;
    GPIOC->OTYPER =1;
    while(true){}
}
void LCD(){
    h1=(h&0xf0)>>4;h2=h&0x0f;
    lib.send_comando(LCD1L+4);
    for (int i=0;i<7;i++){
        lib.send_dato(dato[i]); }
        lib.send_dato((t/10)+0x30);
        lib.send_dato((t%10)+0x30);
        lib.send_comando(LCD2L+4);
    for (int i=0;i<7;i++){
        lib.send_dato(dato2[i]); }
        lib.send_dato(h2+0x30);
        lib.send_dato(h1+0x30);
    }
```







## COMUNICACION A 2 LINES I2C

I2C o Circuito Interintegrado (Inter-Integrated Circuit) es un protocolo de comunicación serial desarrollado por Phillips Semiconductors en la década de los 80s. Se creó para poder comunicar varios chips al mismo tiempo dentro de los televisores.

Con el protocolo I2C es posible tener a varios maestros controlando uno o múltiples esclavos. Esto puede ser de gran ayuda cuando se van a utilizar varios microcontroladores para almacenar un registro de datos hacia una sola memoria o cuando se va a mostrar información en una sola pantalla.



El protocolo I2C utiliza sólo dos vías o cables de comunicación, así como también lo hace el protocolo UART.



SDA – Serial Data. Es la vía de comunicación entre el maestro y el esclavo para enviarse información.

SCL – Serial Clock. Es la vía por donde viaja la señal de reloj.



**I2C es un protocolo de comunicación serial:** envía información a través de una sola vía de comunicación. La información es enviada bit por bit de forma coordinada. Trabaja de forma síncrona, el envío de bits por la vía de comunicación SDA está sincronizado por una señal de reloj que comparten tanto el maestro como el esclavo a través de la vía SCL.

|                  |                                   |
|------------------|-----------------------------------|
| Velocidad máxima | Modo estándar (Sm) = 100kbps      |
|                  | Modo rápido (Fm) = 400kbps        |
|                  | Modo High Speed (Fm+) = 3.4Mbps   |
|                  | Modo Ultra Fast (Hs-mode) = 5Mbps |



La información viaja en mensajes divididos en tramas de datos. Cada mensaje lleva un trama con una dirección la cual transporta la dirección binaria del esclavo al que va dirigido el mensaje, y una o más tramas que llevan la información del mensaje. También el mensaje contiene condiciones de inicio y paro, lectura y escritura de bits, y los bits ACK y NACK.

## Mensaje

| Start               | 7 o 10 Bits                         | Bit para Leer/<br>Escribir | Bit para reconocer<br>ACK/<br>NACK | 8 Bits                                 | Bit para reconocer<br>ACK/<br>NACK | 8 Bits                                 | Bit para reconocer<br>ACK/<br>NACK | Stop              |
|---------------------|-------------------------------------|----------------------------|------------------------------------|----------------------------------------|------------------------------------|----------------------------------------|------------------------------------|-------------------|
| Condición de inicio | Sección destinada para la dirección |                            |                                    | Sección 1 para transportar información |                                    | Sección 2 para transportar información |                                    | Condición de paro |



# Memoria I2C



A control byte is the first byte received following the Start condition from the master device. The control byte consists of a four-bit control code. For the 24XX01, this is set as '1010' binary for read and write operations. The next three bits of the control byte are 'don't care's' for the 24XX01.

The last bit of the control byte defines the operation to be performed. When set to '1', a read operation is selected. When set to '0', a write operation is selected. Following the Start condition, the 24XX01 monitors the SDA bus checking the device type identifier being transmitted. Upon receiving a '1010' code, the slave device outputs an Acknowledge signal on the SDA line. Depending on the state of the R/W bit, the 24XX01 will select a read or write operation.

| Operation | Control Code | Block Select  | R/W |
|-----------|--------------|---------------|-----|
| Read      | 1010         | Block Address | 1   |
| Write     | 1010         | Block Address | 0   |



**FIGURE 4-1:** **BYTE WRITE**



**FIGURE 7-2:** **RANDOM READ**



## Reloj En Tiempo Real (RTC)

Otro dispositivo común para uso del protocolo I<sub>2</sub>C es el reloj en tiempo real de referencia DS107, que requiere un oscilador externo en los pines X<sub>1</sub> y X<sub>2</sub> para manejar la temporización, como se aprecia en la siguiente figura.



Su configuración requiere del uso de la siguiente tabla para programar y leer la hora y calendario.

| PosMem\bit | 7              | 6                   | 5           | 4       | 3                    | 2                | 1 | 0 |  |  |  |
|------------|----------------|---------------------|-------------|---------|----------------------|------------------|---|---|--|--|--|
| 00H        | 0              | Decenas de Segundos |             |         | Unidades de Segundos |                  |   |   |  |  |  |
| 01H        | 0              | Decenas de Minutos  |             |         | Unidades de Minutos  |                  |   |   |  |  |  |
| 02H        | 0              | 12/24               | am/pm       | Dec.H.  | Unidades de Horas    |                  |   |   |  |  |  |
| 03H        | 0              | 0                   | 0           | 0       | 0                    | Dia de la semana |   |   |  |  |  |
| 04H        | 0              | 0                   | Decenas Día |         | Unidades de Día      |                  |   |   |  |  |  |
| 05H        | 0              | 0                   | 0           | Dec. M. | Unidades de Mes      |                  |   |   |  |  |  |
| 06H        | Decenas de Año |                     |             |         | Unidades de Año      |                  |   |   |  |  |  |



## DATA WRITE – SLAVE RECEIVER MODE Figure 6



## DATA READ – SLAVE TRANSMITTER MODE Figure 7



# I<sup>2</sup>C main features

- I<sup>2</sup>C bus specification rev03 compatibility:
  - Slave and master modes
  - Multimaster capability
  - Standard-mode (up to 100 kHz)
  - Fast-mode (up to 400 kHz)
  - Fast-mode Plus (up to 1 MHz)
  - 7-bit and 10-bit addressing mode
  - Multiple 7-bit slave addresses (2 addresses, 1 with configurable mask)
  - All 7-bit addresses acknowledge mode
  - General call
  - Programmable setup and hold times
  - Easy to use event management
  - Optional clock stretching
  - Software reset



| I2C features <sup>(1)</sup>                                 | I2C1 | I2C2 | I2C3 | I2C4 |
|-------------------------------------------------------------|------|------|------|------|
| 7-bit addressing mode                                       | X    | X    | X    | X    |
| 10-bit addressing mode                                      | X    | X    | X    | X    |
| Standard-mode (up to 100 kbit/s)                            | X    | X    | X    | X    |
| Fast-mode (up to 400 kbit/s)                                | X    | X    | X    | X    |
| Fast-mode Plus with 20mA output drive I/Os (up to 1 Mbit/s) | X    | X    | X    | X    |
| Independent clock                                           | X    | X    | X    | X    |

The I2C is clocked by an independent clock source which allows to the I2C to operate independently from the PCLK frequency.

This independent clock source can be selected from the following three clock sources:

- PCLK1: APB1 clock (default value)
- HSI: high speed internal oscillator
- SYSCLK: system clock



## Mode selection

The interface can operate in one of the four following modes:

- Slave transmitter
- Slave receiver
- Master transmitter
- Master receiver

By default, it operates in slave mode. The interface automatically switches from slave to master when it generates a **START** condition, and from master to slave if an arbitration loss or a **STOP** generation occurs, allowing multimaster capability.



## I<sup>2</sup>C master mode

In Master mode, the I<sup>2</sup>C interface initiates a data transfer and generates the clock signal. A serial data transfer always begins with a Start condition and ends with a Stop condition. Master mode is selected as soon as the Start condition is generated on the bus with a START bit.

The following is the required sequence in master mode.

- Program the peripheral input clock in I2C\_CR2 Register in order to generate correct timings
- Configure the clock control registers
- Configure the rise time register
- Program the I2C\_CR1 register to enable the peripheral
- Set the START bit in the I2C\_CR1 register to generate a Start condition



**Figure 164. Transfer sequence diagram for master transmitter**

**7-bit master transmitter**



**10-bit master transmitter**



**Legend:** S= Start,  $S_r$  = Repeated Start, P= Stop, A= Acknowledge,  
 EVx= Event (with interrupt if ITEVFEN = 1)

**EV5:** SB=1, cleared by reading SR1 register followed by writing DR register with Address.

**EV6:** ADDR=1, cleared by reading SR1 register followed by reading SR2.

**EV8\_1:** TxE=1, shift register empty, data register empty, write Data1 in DR.

**EV8:** TxE=1, shift register not empty,.data register empty, cleared by writing DR register

**EV8\_2:** TxE=1, BTF = 1, Program Stop request. TxE and BTF are cleared by hardware by the Stop condition

**EV9:** ADD10=1, cleared by reading SR1 register followed by writing DR register.

ai18210

1. The EV5, EV6, EV9, EV8\_1 and EV8\_2 events stretch SCL low until the end of the corresponding software sequence.
2. The EV8 event stretches SCL low if the software sequence is not complete before the end of the next byte transmission.

Figure 164. Transfer sequence diagram for master transmitter

7-bit master transmitter



### I<sup>2</sup>C Status register 1 (I<sup>2</sup>C\_SR1)

| 15        | 14       | 13   | 12      | 11    | 10    | 9     | 8     | 7   | 6    | 5    | 4     | 3     | 2   | 1    | 0  |
|-----------|----------|------|---------|-------|-------|-------|-------|-----|------|------|-------|-------|-----|------|----|
| SMB ALERT | TIME OUT | Res. | PEC ERR | OVR   | AF    | ARLO  | BERR  | TxE | RxNE | Res. | STOPF | ADD10 | BTF | ADDR | SB |
| rc_w0     | rc_w0    |      | rc_w0   | rc_w0 | rc_w0 | rc_w0 | rc_w0 | r   | r    |      | r     | r     | r   | r    | r  |

```
I2C1->CR1 |= (1<<8);
while (!(I2C1->SR1 & 0x01));
```

```
while (!(I2C1->SR1 & (1<<1)));
while (!(I2C1->SR1 & (1<<7)));
```

```
I2C1->CR1 |= (1<<9);
while (I2C1->SR2 & 0x0002);
```

EV5: SB=1, cleared by reading SR1 register followed by writing DR register with Address.

EV6: ADDR=1, cleared by reading SR1 register followed by reading SR2.

EV8\_1: TxE=1, shift register empty, data register empty, write Data1 in DR.

EV8: TxE=1, shift register not empty, data register empty, cleared by writing DR register

EV8\_2: TxE=1, BTF = 1, Program Stop request. TxE and BTF are cleared by hardware by the Stop condition

EV9: ADD10=1, cleared by reading SR1 register followed by writing DR register.



### 6.3.11 RCC APB1 peripheral clock enable register (RCC\_APB1ENR)

|          |    |    |        |          |    |    |         |         |         |          |    |    |           |               |    |
|----------|----|----|--------|----------|----|----|---------|---------|---------|----------|----|----|-----------|---------------|----|
| 31       | 30 | 29 | 28     | 27       | 26 | 25 | 24      | 23      | 22      | 21       | 20 | 19 | 18        | 17            | 16 |
| Reserved |    |    | PWR EN | Reserved |    |    | I2C3 EN | I2C2 EN | I2C1 EN | Reserved |    |    | USART2 EN | Reser-<br>ved |    |
|          |    |    | rw     |          |    |    | rw      | rw      | rw      |          |    |    | rw        |               |    |



Table 9. Alternate function mapping

| Port | AF00     | AF01      | AF02                | AF03                     | AF04               | AF05                                  | AF06                     | AF07                          |
|------|----------|-----------|---------------------|--------------------------|--------------------|---------------------------------------|--------------------------|-------------------------------|
|      | SYS_AF   | TIM1/TIM2 | TIM3/<br>TIM4/ TIM5 | TIM9/<br>TIM10/<br>TIM11 | I2C1/I2C2/<br>I2C3 | SPI1/SPI2/<br>I2S2/SPI3/<br>I2S3/SPI4 | SPI2/I2S2/<br>SPI3/ I2S3 | SPI3/I2S:<br>USART1<br>USART2 |
| PB0  | -        | TIM1_CH2N | TIM3_CH3            | -                        | -                  | -                                     | -                        | -                             |
| PB1  | -        | TIM1_CH3N | TIM3_CH4            | -                        | -                  | -                                     | -                        | -                             |
| PB2  | -        | -         | -                   | -                        | -                  | -                                     | -                        | -                             |
| PB3  | JTDO-SWO | TIM2_CH2  | -                   | -                        | -                  | SPI1_SCK                              | SPI3_SCK/<br>I2S3_CK     | -                             |
| PB4  | JTRST    | -         | TIM3_CH1            | -                        | -                  | SPI1_MISO                             | SPI3_MISO                | I2S3ext_D                     |
| PB5  | -        | -         | TIM3_CH2            | -                        | I2C1_SMBA          | SPI1_MOSI                             | SPI3_MOSI/<br>I2S3_SD    | -                             |
| PB6  | -        | -         | TIM4_CH1            | -                        | I2C1_SCL           | -                                     | -                        | USART1_TX                     |
| PB7  | -        | -         | TIM4_CH2            | -                        | I2C1_SDA           | -                                     | -                        | USART1_RX                     |
| PB8  | -        | -         | TIM4_CH3            | TIM10_CH1                | I2C1_SCL           | -                                     | -                        | -                             |
| PB9  | -        | -         | TIM4_CH4            | TIM11_CH1                | I2C1_SDA           | SPI2_NSS/I<br>I2S2_WS                 | -                        | -                             |
| PB10 | -        | TIM2_CH3  | -                   | -                        | I2C2_SCL           | SPI2_SCK/I<br>I2S2_CK                 | -                        | -                             |
| PB12 | -        | TIM1_BKIN | -                   | -                        | I2C2_SMBA          | SPI2_NSS/I<br>I2S2_WS                 | -                        | -                             |



## 18.6.2 I<sup>2</sup>C Control register 2 (I2C\_CR2)

Address offset: 0x04

Reset value: 0x0000



```
I2C1->CR2 |= (42<< 0);
```



## 18.6.8 I<sup>2</sup>C Clock control register (I2C\_CCR)

Address offset: 0x1C

Reset value: 0x0000

Note:  $f_{PCLK1}$  must be at least 2 MHz to achieve Sm mode I<sup>2</sup>C frequencies. It must be at least 4 MHz to achieve Fm mode I<sup>2</sup>C frequencies. It must be a multiple of 10MHz to reach the 400 kHz maximum I<sup>2</sup>C Fm mode clock.

$$CCR = \frac{T_{r(SCL)} + T_{w(SCLH)}}{T_{PCLK1}}$$

The CCR register must be config

Table 61. I<sup>2</sup>C characteristics

| 15  | 14   | 13       | 12 | 11 | 10 | 9 |
|-----|------|----------|----|----|----|---|
| F/S | DUTY | Reserved |    |    |    |   |
| rw  | rw   |          | rw | rw | rw | r |

Bits 11:0 CCR[11:0]: Clock control register in Fm/Sm mode (Master mode)

Controls the SCL clock in master mode.

Sm mode or SMBus:

$$T_{high} = CCR * T_{PCLK1}$$

$$T_{low} = CCR * T_{PCLK1}$$

Fm mode:

If DUTY = 0:

$$T_{high} = CCR * T_{PCLK1}$$

$$T_{low} = 2 * CCR * T_{PCLK1}$$

If DUTY = 1: (to reach 400 kHz)

$$T_{high} = 9 * CCR * T_{PCLK1}$$

$$T_{low} = 16 * CCR * T_{PCLK1}$$

For instance: in Sm mode, to generate a 100 kHz SCL clock

If FREQR = 08,  $T_{PCLK1} = 125$  ns so CCR must be 0x28 (0x28 => 40d x 125 ns = 5000 ns.)

| Symbol                   | Parameter                                                                                     | Standard mode I <sup>2</sup> C <sup>(1)(2)</sup> |                     | Fast mode I <sup>2</sup> C <sup>(1)(2)</sup> |                     | Unit |
|--------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------|----------------------------------------------|---------------------|------|
|                          |                                                                                               | Min                                              | Max                 | Min                                          | Max                 |      |
| $t_{w(SCL)}$             | SCL clock low time                                                                            | 4.7                                              | -                   | 1.3                                          | -                   | μs   |
| $t_{w(SCLH)}$            | SCL clock high time                                                                           | 4.0                                              | -                   | 0.6                                          | -                   |      |
| $t_{su(SDA)}$            | SDA setup time                                                                                | 250                                              | -                   | 100                                          | -                   |      |
| $t_h(SDA)$               | SDA data hold time                                                                            | -                                                | 3450 <sup>(3)</sup> | -                                            | 900 <sup>(4)</sup>  |      |
| $t_v(SDA, ACK)$          | Data, ACK valid time                                                                          | -                                                | 3.45                | -                                            | 0.9                 |      |
| $t_r(SDA)$<br>$t_r(SCL)$ | SDA and SCL rise time                                                                         | -                                                | 1000                | -                                            | 300                 |      |
| $t_f(SDA)$<br>$t_f(SCL)$ | SDA and SCL fall time                                                                         | -                                                | 300                 | -                                            | 300                 | ns   |
| $t_h(STA)$               | Start condition hold time                                                                     | 4.0                                              | -                   | 0.6                                          | -                   | μs   |
| $t_{su(STA)}$            | Repeated Start condition setup time                                                           | 4.7                                              | -                   | 0.6                                          | -                   |      |
| $t_{su(STO)}$            | Stop condition setup time                                                                     | 4.0                                              | -                   | 0.6                                          | -                   |      |
| $t_w(STO:STA)$           | Stop to Start condition time (bus free)                                                       | 4.7                                              | -                   | 1.3                                          | -                   |      |
| $t_{SP}$                 | Pulse width of the spikes that are suppressed by the analog filter for standard and fast mode | -                                                | -                   | 0.05                                         | 0.09 <sup>(5)</sup> | μs   |

## 18.6.8 I<sup>2</sup>C Clock control register (I2C\_CCR)



Table 61. I<sup>2</sup>C characteristics

| Symbol                   | Parameter                                                                                     | Standard mode I <sup>2</sup> C <sup>(1)(2)</sup> |                     | Fast mode I <sup>2</sup> C <sup>(1)(2)</sup> |                     | Unit |
|--------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------|----------------------------------------------|---------------------|------|
|                          |                                                                                               | Min                                              | Max                 | Min                                          | Max                 |      |
| $t_w(SCLL)$              | SCL clock low time                                                                            | 4.7                                              | -                   | 1.3                                          | -                   | μs   |
| $t_w(SCLH)$              | SCL clock high time                                                                           | 4.0                                              | -                   | 0.6                                          | -                   | ns   |
| $t_{su}(SDA)$            | SDA setup time                                                                                | 250                                              | -                   | 100                                          | -                   | ns   |
| $t_h(SDA)$               | SDA data hold time                                                                            | -                                                | 3450 <sup>(3)</sup> | -                                            | 900 <sup>(4)</sup>  | ns   |
| $t_v(SDA, ACK)$          | Data, ACK valid time                                                                          | -                                                | 3.45                | -                                            | 0.9                 | ns   |
| $t_r(SDA)$<br>$t_r(SCL)$ | SDA and SCL rise time                                                                         | -                                                | 1000                | -                                            | 300                 | ns   |
| $t_f(SDA)$<br>$t_f(SCL)$ | SDA and SCL fall time                                                                         | -                                                | 300                 | -                                            | 300                 | ns   |
| $t_h(STA)$               | Start condition hold time                                                                     | 4.0                                              | -                   | 0.6                                          | -                   | μs   |
| $t_{su}(STA)$            | Repeated Start condition setup time                                                           | 4.7                                              | -                   | 0.6                                          | -                   | μs   |
| $t_{su}(STO)$            | Stop condition setup time                                                                     | 4.0                                              | -                   | 0.6                                          | -                   | μs   |
| $t_w(STO:STA)$           | Stop to Start condition time (bus free)                                                       | 4.7                                              | -                   | 1.3                                          | -                   | μs   |
| $t_{SP}$                 | Pulse width of the spikes that are suppressed by the analog filter for standard and fast mode | -                                                | -                   | 0.05                                         | 0.09 <sup>(5)</sup> | μs   |

## 24.6.9 I<sup>2</sup>C TRISE register (I2C\_TRISE)

$$\text{TRISE} = \frac{T_{r(\text{SCL})}}{T_{\text{PCLK1}}} + 1$$

Address offset: 0x20

Reset value: 0x0002

| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0          |    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------------|----|
| Res | TRISE[5:0] |    |
|     |     |     |     |     |     |     |     |     |     |     |     | rw  | rw  | rw  | rw         | rw |

Bits 15:6 Reserved, must be kept at reset value

Bits 5:0 **TRISE[5:0]**: Maximum rise time in Fm/Sm mode (Master mode)

These bits should provide the maximum duration of the SCL feedback loop in master mode.

The purpose is to keep a stable SCL frequency whatever the SCL rising edge duration.

These bits must be programmed with the maximum SCL rise time given in the I<sup>2</sup>C bus specification, incremented by 1.

For instance: in Sm mode, the maximum allowed SCL rise time is 1000 ns.

If, in the I2C\_CR2 register, the value of FREQ[5:0] bits is equal to 0x08 and T<sub>PCLK1</sub> = 125 ns therefore the TRISE[5:0] bits must be programmed with 09h.

(1000 ns / 125 ns = 8 + 1)

The filter value can also be added to TRISE[5:0].

If the result is not an integer, TRISE[5:0] must be programmed with the integer part, in order to respect the t<sub>HIGH</sub> parameter.

*Note: TRISE[5:0] must be configured only when the I2C is disabled (PE = 0).*



# Memoria I2C

FIGURE 4-1: BYTE WRITE



```

void escr () {
    I2C1->CR1 |= (1<<8);
    while (!(I2C1->SR1 & 0x01));
    while (!(I2C1->SR1 & (1<<7)));
    | I2C1->DR = 0xA0; //dirección
    while (!(I2C1->SR1 & (1<<1)));
    while (!(I2C1->SR1 & (1<<7)));
    I2C1->DR = 0x05;
    while (!(I2C1->SR1 & (1<<7)));
    I2C1->DR = 0x68;
    while (!(I2C1->SR1 & (1<<2)));
    I2C1->CR1 |= (1<<9);
    while (I2C1->SR2 & 0x0002);
    WORK;
}

```

## Communication flow

In Master mode, the I2C interface initiates a data transfer and generates the clock signal. A serial data transfer always begins with a START condition and ends with a STOP condition. Both START and STOP conditions are generated in master mode by software.

In Slave mode, the interface is capable of recognizing its own addresses (7 or 10-bit), and the General Call address. The General Call address detection can be enabled or disabled by software. The reserved SMBus addresses can also be enabled by software.

Data and addresses are transferred as 8-bit bytes, MSB first. The first byte(s) following the START condition contain the address (one in 7-bit mode, two in 10-bit mode). The address is always transmitted in Master mode.



# Reception

The SDA input fills the shift register. After the 8th SCL pulse (when the complete data byte is received), the shift register is copied into I2C\_RXDR register if it is empty (RXNE=0). If RXNE=1, meaning that the previous received data byte has not yet been read, the SCL line is stretched low until I2C\_RXDR is read. The stretch is inserted between the 8th and 9th SCL pulse (before the Acknowledge pulse).

Figure 307. Data reception



# Transmission

If the I2C\_TXDR register is not empty ( $\text{TXE}=0$ ), its content is copied into the shift register after the 9th SCL pulse (the Acknowledge pulse). Then the shift register content is shifted out on SDA line. If  $\text{TXE}=1$ , meaning that no data is written yet in I2C\_TXDR, SCL line is stretched low until I2C\_TXDR is written. The stretch is done after the 9th SCL pulse.

Figure 308. Data transmission



## Ejemplo stm32f7:

Diseñar un programa que permita enviar y recibir un dato a través del modulo I<sub>2</sub>C.

### **Puertos y Pines:**

- PF1-SCL (Reloj).
- PF0-SDA (Datos).
- Modulo I<sub>2</sub>C



# RCC\_AHB1ENR peripheral clock register.

**RCC->AHB1ENR |= 0x00000020; // Encender reloj puertoE**

| 31   | 30              | 29          | 28                  | 27                 | 26                 | 25           | 24          | 23          | 22          | 21          | 20            | 19          | 18            | 17          | 16          |
|------|-----------------|-------------|---------------------|--------------------|--------------------|--------------|-------------|-------------|-------------|-------------|---------------|-------------|---------------|-------------|-------------|
| Res. | OTGHS<br>ULPIEN | OTGHS<br>EN | ETHM<br>ACPTP<br>EN | ETHM<br>ACRX<br>EN | ETHM<br>ACTX<br>EN | ETHMA<br>CEN | Res.        | DMA2D<br>EN | DMA2<br>EN  | DMA1<br>EN  | DTCMRA<br>MEN | Res.        | BKPSR<br>AMEN | Res.        | Res.        |
|      | rw              | rw          | rw                  | rw                 | rw                 | rw           |             | rw          | rw          | rw          | rw            |             | rw            |             |             |
| 15   | 14              | 13          | 12                  | 11                 | 10                 | 9            | 8           | 7           | 6           | 5           | 4             | 3           | 2             | 1           | 0           |
| Res. | Res.            | Res.        | CRC<br>EN           | Res.               | GPIOK<br>EN        | GPIOJ<br>EN  | GPIOI<br>EN | GPIOH<br>EN | GPIOG<br>EN | GPIOF<br>EN | GPIOE<br>EN   | GPIOD<br>EN | GPIOC<br>EN   | GPIO<br>BEN | GPIO<br>AEN |
|      |                 |             | rw                  |                    | rw                 | rw           | rw          | rw          | rw          | rw          | rw            | rw          | rw            | rw          | rw          |



# Asignación de Puertos PF0 y PF1.

```
GPIOF->AFR[0] |= 0x00000044; // seleccion de la funcion alterna 4 del puerto F(I2C) para PF1-SCL,PF0-SDA -> I2C2
```

Table 12. STM32F745xx and STM32F746

| Port   |      | AF0    | AF1           | AF2                             | AF3                | AF4                | AF5           | AF6           |
|--------|------|--------|---------------|---------------------------------|--------------------|--------------------|---------------|---------------|
|        | SYS  | TIM1/2 | TIM3/4/5      | TIM8/9/10/<br>11/LPTIM<br>1/CEC | I2C1/2/3/<br>4/CEC | SPI1/2/3/<br>4/5/6 | SPI3/<br>SAI1 | SPI4/<br>SAI2 |
| Port E | PE14 | -      | TIM1_C<br>H4  | -                               | -                  | -                  | SPI4_M<br>OSI | -             |
|        | PE15 | -      | TIM1_B<br>KIN | -                               | -                  | -                  | -             | -             |
|        | PF0  | -      | -             | -                               | -                  | I2C2_SD<br>A       | -             | -             |
|        | PF1  | -      | -             | -                               | -                  | I2C2_SC<br>L       | -             | -             |
|        | PF2  | -      | -             | -                               | -                  | I2C2_SM<br>BA      | -             | -             |
|        | PF3  | -      | -             | -                               | -                  | -                  | -             | -             |



# GPIOx\_Moder port moder register

```
GPIOF->MODER |= 0x0000000A; // PFO, PF1 => en modo alterno
```

| 31           | 30 | 29           | 28 | 27           | 26 | 25           | 24 | 23           | 22 | 21           | 20 | 19          | 18 | 17          | 16 |
|--------------|----|--------------|----|--------------|----|--------------|----|--------------|----|--------------|----|-------------|----|-------------|----|
| MODER15[1:0] |    | MODER14[1:0] |    | MODER13[1:0] |    | MODER12[1:0] |    | MODER11[1:0] |    | MODER10[1:0] |    | MODER9[1:0] |    | MODER8[1:0] |    |
| rw           | rw | rw          | rw | rw          | rw |
| 15           | 14 | 13           | 12 | 11           | 10 | 9            | 8  | 7            | 6  | 5            | 4  | 3           | 2  | 1           | 0  |
| MODER7[1:0]  |    | MODER6[1:0]  |    | MODER5[1:0]  |    | MODER4[1:0]  |    | MODER3[1:0]  |    | MODER2[1:0]  |    | MODER1[1:0] |    | MODER0[1:0] |    |
| rw           | rw | rw          | rw | rw          | rw |

Bits  $2y+1:2y$  **MODER $y[1:0]$** : Port x configuration bits ( $y = 0..15$ )

These bits are written by software to configure the I/O mode.

00: Input mode (reset state)

01: General purpose output mode

10: Alternate function mode

11: Analog mode



# GPIOx\_OTYPER port output type register.

```
GPIOE->OTYPER |= 0x0003; // Open drain
```

| 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| Res. |
|      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |      |
| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| OT15 | OT14 | OT13 | OT12 | OT11 | OT10 | OT9  | OT8  | OT7  | OT6  | OT5  | OT4  | OT3  | OT2  | OT1  | OT0  |
| rw   |

Bits 31:16 Reserved, must be kept at reset value.

Bits 15:0 **OTy**: Port x configuration bits ( $y = 0..15$ )

These bits are written by software to configure the I/O output type.

0: Output push-pull (reset state)

1: Output open-drain



# GPIOx\_PUPDR port pull-up/pull-down register.

**GPIOF->PUPDR |= 0x5;**

| 31           | 30           | 29           | 28           | 27           | 26           | 25          | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|----|----|----|----|----|----|----|----|
| PUPDR15[1:0] | PUPDR14[1:0] | PUPDR13[1:0] | PUPDR12[1:0] | PUPDR11[1:0] | PUPDR10[1:0] | PUPDR9[1:0] | PUPDR8[1:0] |    |    |    |    |    |    |    |    |
| rw           | rw           | rw           | rw           | rw           | rw           | rw          | rw          | rw | rw | rw | rw | rw | rw | rw | rw |
| 15           | 14           | 13           | 12           | 11           | 10           | 9           | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| PUPDR7[1:0]  | PUPDR6[1:0]  | PUPDR5[1:0]  | PUPDR4[1:0]  | PUPDR3[1:0]  | PUPDR2[1:0]  | PUPDR1[1:0] | PUPDR0[1:0] |    |    |    |    |    |    |    |    |
| rw           | rw           | rw           | rw           | rw           | rw           | rw          | rw          | rw | rw | rw | rw | rw | rw | rw | rw |

Bits 2y+1:2y **PUPDR<sub>y</sub>[1:0]**: Port x configuration bits ( $y = 0..15$ )

These bits are written by software to configure the I/O pull-up or pull-down

00: No pull-up, pull-down

01: Pull-up

10: Pull-down

11: Reserved



# GPIOx\_OSPEEDR port output speed register.

**GPIOF->OSPEEDR** |= **0xC;**

| 31              | 30 | 29              | 28 | 27              | 26 | 25              | 24 | 23              | 22 | 21              | 20 | 19             | 18 | 17             | 16 |
|-----------------|----|-----------------|----|-----------------|----|-----------------|----|-----------------|----|-----------------|----|----------------|----|----------------|----|
| OSPEEDR15 [1:0] |    | OSPEEDR14 [1:0] |    | OSPEEDR13 [1:0] |    | OSPEEDR12 [1:0] |    | OSPEEDR11 [1:0] |    | OSPEEDR10 [1:0] |    | OSPEEDR9 [1:0] |    | OSPEEDR8 [1:0] |    |
| rw              | rw | rw             | rw | rw             | rw |
| 15              | 14 | 13              | 12 | 11              | 10 | 9               | 8  | 7               | 6  | 5               | 4  | 3              | 2  | 1              | 0  |
| OSPEEDR7 [1:0]  |    | OSPEEDR6 [1:0]  |    | OSPEEDR5 [1:0]  |    | OSPEEDR4 [1:0]  |    | OSPEEDR3 [1:0]  |    | OSPEEDR2 [1:0]  |    | OSPEEDR1 [1:0] |    | OSPEEDR0 [1:0] |    |
| rw              | rw | rw             | rw | rw             | rw |

Bits 2y+1:2y **OSPEEDR<sub>y</sub>[1:0]**: Port x configuration bits ( $y = 0..15$ )

These bits are written by software to configure the I/O output speed.

00: Low speed

01: Medium speed

10: High speed

11: Very high speed



# RCC\_APB1ENR peripheral clock enable register.

```
RCC->APB1ENR |= 0x00400000; // Enable clock for I2C2 bit 22
```

| 31       | 30       | 29     | 28     | 27      | 26      | 25        | 24       | 23       | 22       | 21      | 20       | 19       | 18        | 17        | 16         |
|----------|----------|--------|--------|---------|---------|-----------|----------|----------|----------|---------|----------|----------|-----------|-----------|------------|
| UART8 EN | UART7 EN | DAC EN | PWR EN | CEC EN  | CAN2 EN | CAN1 EN   | I2C4 EN  | I2C3 EN  | I2C2 EN  | I2C1 EN | UART5 EN | UART4 EN | USART3 EN | USART2 EN | SPDIFRX EN |
| rw       | rw       | rw     | rw     | rw      | rw      | rw        |          | rw       | rw       | rw      | rw       | rw       | rw        | rw        | rw         |
| 15       | 14       | 13     | 12     | 11      | 10      | 9         | 8        | 7        | 6        | 5       | 4        | 3        | 2         | 1         | 0          |
| SPI3 EN  | SPI2 EN  | Res.   | Res.   | WWDG EN | Res.    | LPTIM1 EN | TIM14 EN | TIM13 EN | TIM12 EN | TIM7 EN | TIM6 EN  | TIM5 EN  | TIM4 EN   | TIM3 EN   | TIM2 EN    |
| rw       | rw       |        |        | rw      |         | rw        | rw       | rw       | rw       | rw      | rw       | rw       | rw        | rw        | rw         |

Bit 22 **I2C2EN**: I2C2 clock enable

This bit is set and cleared by software.

0: I2C2 clock disabled

1: I2C2 clock enabled



# DCKCFGR2 dedicated clocks configuration register.

RCC->DCKCFGR2 |= 0x80000;

//Reloj de frecuencia del I2C2

This register allows to select the source clock for the 48MHz, SDMMC, HDMI-CEC, LPTIM1, UARTs, USARTs and I2Cs clocks.

|          |          |           |            |           |          |           |          |         |    |         |    |         |    |    |    |
|----------|----------|-----------|------------|-----------|----------|-----------|----------|---------|----|---------|----|---------|----|----|----|
| 31       | 30       | 29        | 28         | 27        | 26       | 25        | 24       | 23      | 22 | 21      | 20 | 19      | 18 | 17 | 16 |
| Res.     | Res.     | Res.      | SDMM C1SEL | CK48M SEL | CECSEL   | LPTIM1SEL | I2C4SEL  | I2C3SEL |    | I2C2SEL |    | I2C1SEL |    |    |    |
|          |          |           | rw         | rw        | rw       | rw        | rw       | rw      | rw | rw      | rw | rw      | rw | rw | rw |
| 15       | 14       | 13        | 12         | 11        | 10       | 9         | 8        | 7       | 6  | 5       | 4  | 3       | 2  | 1  | 0  |
| UART8SEL | UART7SEL | USART6SEL | UART5SEL   | UART4SEL  | UART3SEL | UART2SEL  | UART1SEL |         |    |         |    |         |    |    |    |
| rw       | rw       | rw        | rw         | rw        | rw       | rw        | rw       | rw      | rw | rw      | rw | rw      | rw | rw | rw |

Bits 19:18 **I2C2SEL**: I2C2 clock source selection

Set and reset by software.

00: APB1 clock (PCLK1) is selected as I2C2 clock

01: System clock is selected as I2C2 clock

10: HSI clock is selected as I2C2 clock

11: reserved



# Control Register (I2C\_CR1)

```
// Disable the I2Cx peripheral
I2C2->CR1 &= ~I2C_CR1_PE; //deshabilita SCL y SDA para el periferico
while (I2C2->CR1 & I2C_CR1_PE);
```

|          |          |      |         |      |      |      |       |          |         |         |         |      |           |     |    |
|----------|----------|------|---------|------|------|------|-------|----------|---------|---------|---------|------|-----------|-----|----|
| 31       | 30       | 29   | 28      | 27   | 26   | 25   | 24    | 23       | 22      | 21      | 20      | 19   | 18        | 17  | 16 |
| Res.     | Res.     | Res. | Res.    | Res. | Res. | Res. | PECEN | ALERT EN | SMBD EN | SMBH EN | GCEN    | Res. | NOSTRETCH | SBC |    |
|          |          |      |         |      |      |      | rw    | rw       | rw      | rw      | rw      |      | rw        | rw  | rw |
| 15       | 14       | 13   | 12      | 11   | 10   | 9    | 8     | 7        | 6       | 5       | 4       | 3    | 2         | 1   | 0  |
| RXDMA EN | TXDMA EN | Res. | ANF OFF | DNF  |      |      | ERRIE | TCIE     | STOP IE | NACK IE | ADDR IE | RXIE | TXIE      | PE  |    |
| rw       | rw       |      | rw      | rw   |      |      | rw    | rw       | rw      | rw      | rw      | rw   | rw        | rw  | rw |

Bit 0 **PE**: Peripheral enable

0: Peripheral disable

1: Peripheral enable



Los tiempos deben ser configurados de tal forma que permitan la transferencia y configuración de información usada en los módulos maestros y esclavos. Esto se logra mediante la configuración del PRESC, SCLDEL, SDADEL, en el registro I2C\_TIMINGR.

**Figure 288. I2C initialization flowchart**



Los tiempos deben ser configurados de tal forma que permitan la transferencia y configuración de información usada en los módulos maestros y esclavos. Esto se logra mediante la configuración del PRESC, SCLDEL, SDADEL, en el registro I2C\_TIMINGR.

**Table 161. Examples of timings settings for  $f_{I2CCLK} = 16 \text{ MHz}$**

| Parameter       | Standard-mode (Sm)                           |                                              | Fast-mode (Fm)                               | Fast-mode Plus (Fm+)                          |
|-----------------|----------------------------------------------|----------------------------------------------|----------------------------------------------|-----------------------------------------------|
|                 | 10 kHz                                       | 100 kHz                                      | 400 kHz                                      | 1000 kHz                                      |
| PRESC           | 3                                            | 3                                            | 1                                            | 0                                             |
| SCLL            | 0xC7                                         | 0x13                                         | 0x9                                          | 0x4                                           |
| $t_{SCLL}$      | $200 \times 250 \text{ ns} = 50 \mu\text{s}$ | $20 \times 250 \text{ ns} = 5.0 \mu\text{s}$ | $10 \times 125 \text{ ns} = 1250 \text{ ns}$ | $5 \times 62.5 \text{ ns} = 312.5 \text{ ns}$ |
| SCLH            | 0xC3                                         | 0xF                                          | 0x3                                          | 0x2                                           |
| $t_{SCLH}$      | $196 \times 250 \text{ ns} = 49 \mu\text{s}$ | $16 \times 250 \text{ ns} = 4.0 \mu\text{s}$ | $4 \times 125 \text{ ns} = 500 \text{ ns}$   | $3 \times 62.5 \text{ ns} = 187.5 \text{ ns}$ |
| $t_{SCL}^{(1)}$ | $\sim 100 \mu\text{s}^{(2)}$                 | $\sim 10 \mu\text{s}^{(2)}$                  | $\sim 2500 \text{ ns}^{(3)}$                 | $\sim 1000 \text{ ns}^{(4)}$                  |
| SDADEL          | 0x2                                          | 0x2                                          | 0x2                                          | 0x0                                           |
| $t_{SDADEL}$    | $2 \times 250 \text{ ns} = 500 \text{ ns}$   | $2 \times 250 \text{ ns} = 500 \text{ ns}$   | $2 \times 125 \text{ ns} = 250 \text{ ns}$   | 0 ns                                          |
| SCLDEL          | 0x4                                          | 0x4                                          | 0x3                                          | 0x2                                           |
| $t_{SCLDEL}$    | $5 \times 250 \text{ ns} = 1250 \text{ ns}$  | $5 \times 250 \text{ ns} = 1250 \text{ ns}$  | $4 \times 125 \text{ ns} = 500 \text{ ns}$   | $3 \times 62.5 \text{ ns} = 187.5 \text{ ns}$ |



Figure 287. Setup and hold timings



Data hold time: in case of transmission, the data is sent on SDA output after the SDADEL delay, if it is already available in I2C\_TXDR.



Data setup time: in case of transmission, the SCLDEL counter starts when the data is sent on SDA output.

### 30.7.5 Timing register (I2C\_TIMINGR)

**PRESC = 3  
SCLDEL = 4  
SDADEL = 2  
SCLH = 15  
SCLL=19**

Address offset: 0x10

Reset value: 0x0000 0000

## Access: No wait states

```
I2C2->TIMINGR |= 0x30420F13;
```

## //I2C2 Timing config

110000010000100000111100010011



Bits 31:28 **PRESC[3:0]**: Timing prescaler

This field is used to prescale I<sub>2</sub>CCLK in order to generate the clock period  $t_{PRESC}$  used for data setup and hold counters (refer to [I<sub>2</sub>C timings on page 923](#)) and for SCL high and low level counters (refer to [I<sub>2</sub>C master initialization on page 938](#)).

$$t_{PRESC} = (PRESC+1) \times t_{I2CCLK}$$

Bits 23:20 **SCLDEL[3:0]**: Data setup time

This field is used to generate a delay  $t_{SCLDEL}$  between SDA edge and SCL rising edge. In master mode and in slave mode with NOSTRETCH = 0, the SCL line is stretched low during  $t_{SCLDEL}$ .

$$t_{SCLDEL} = (SCLDEL+1) \times t_{PRESC}$$

*Note:*  $t_{SCLDEL}$  is used to generate  $t_{SU:DAT}$  timing.

Bits 19:16 **SDADEL[3:0]**: Data hold time

This field is used to generate the delay  $t_{SDADEL}$  between SCL falling edge and SDA edge. In master mode and in slave mode with NOSTRETCH = 0, the SCL line is stretched low during  $t_{SDADEL}$ .

$$t_{SDADEL} = SDADEL \times t_{PRESC}$$

*Note:*  $t_{SDADEL}$  is used to generate  $t_{HD:DAT}$  timing.

Bits 15:8 **SCLH[7:0]**: SCL high period (master mode)

This field is used to generate the SCL high period in master mode.

$$t_{SCLH} = (SCLH+1) \times t_{PRESC}$$

*Note:*  $t_{SCLH}$  is also used to generate  $t_{SU:STO}$  and  $t_{HD:STA}$  timing.

Bits 7:0 **SCLL[7:0]**: SCL low period (master mode)

This field is used to generate the SCL low period in master mode.

$$t_{SCLL} = (SCLL+1) \times t_{PRESC}$$

*Note:*  $t_{SCLL}$  is also used to generate  $t_{BUF}$  and  $t_{SU:STA}$  timings.

$$t_{PRESC} = (PRESC + 1) * t_{I2CCLK}$$

$$t_{PRESC} = (3 + 1) * 62,5\text{ns}$$

$$t_{PRESC} = 250\text{ns}$$

$$t_{SCLDEL} = (SCLDEL + 1) * t_{PRESC}$$

$$t_{SCLDEL} = (4 + 1) * 250\text{ns}$$

$$t_{SCLDEL} = 1,25\text{us}$$

$$t_{SDADEL} = (SDADEL) * t_{PRESC}$$

$$t_{SDADEL} = (2) * 250\text{ns}$$

$$t_{SDADEL} = 500\text{ns}$$

$$t_{SCLH} = (SCLH + 1) * t_{PRESC}$$

$$t_{SCLH} = (15 + 1) * 250\text{ns}$$

$$t_{SCLH} = 4\text{us}$$

$$t_{SCLL} = (SCLL + 1) * t_{PRESC}$$

$$t_{SCLL} = (19 + 1) * 250\text{ns}$$

$$t_{SCLL} = 5\text{us}$$



### 30.7.2 Control register 2 (I2C\_CR2)

Address offset: 0x04

NBYTES = 2

Reset value: 0x0000 0000

SADD = 0X7E -> Solo es valido para este ejemplo

Access: No wait states, except if a write access occurs while a write access to this register is ongoing. In this case, wait states are inserted in the second write access until the previous one is completed. The latency of the second write access can be up to 2 x PCLK1 + 6 x I2CCLK.

| 000000010 |      |       |             |       |             |             |            |             |    |    |    |    |    |    |    |
|-----------|------|-------|-------------|-------|-------------|-------------|------------|-------------|----|----|----|----|----|----|----|
| 31        | 30   | 29    | 28          | 27    | 0           | 1           | 0          | 23          | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Res.      | Res. | Res.  | Res.        | Res.  | PEC<br>BYTE | AUTO<br>END | RE<br>LOAD | NBYTES[7:0] |    |    |    |    |    |    |    |
|           |      |       |             |       | rs          | rw          | rw         | rw          |    |    |    |    |    |    |    |
| 15        | 14   | 13    | 12          | 11    | 10          | 9           | 8          | 7           | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| NACK      | STOP | START | HEAD<br>10R | ADD10 | RD_<br>WRN  | SADD[9:0]   |            |             |    |    |    |    |    |    |    |
| rs        | rs   | rs    | rw          | rw    | rw          | rw          |            |             |    |    |    |    |    |    |    |
| 0         | 0    | 1     | 0           | 0     | 0           | 000111110   |            |             |    |    |    |    |    |    |    |

I2C2->CR2 |= 0x0202207E;

10000000100010000001111110



Bit 13 **START**: Start generation

This bit is set by software, and cleared by hardware after the Start followed by the address sequence is sent, by an arbitration loss, by a timeout error detection, or when PE = 0. It can also be cleared by software by writing '1' to the ADDRCF bit in the I2C\_ICR register.

0: No Start generation.

**1: Restart/Start generation:**

- If the I2C is already in master mode with AUTOEND = 0, setting this bit generates a Repeated Start condition when RELOAD=0, after the end of the NBYTES transfer.
- Otherwise setting this bit will generate a START condition once the bus is free.

*Note: Writing '0' to this bit has no effect.*

*The START bit can be set even if the bus is BUSY or I2C is in slave mode.*

*This bit has no effect when RELOAD is set. In 10-bit addressing mode, if a NACK is received on the first part of the address, the START bit is not cleared by hardware and the master will resend the address sequence, unless the START bit is cleared by software*

Bit 25 **AUTOEND**: Automatic end mode (master mode)

This bit is set and cleared by software.

0: software end mode: TC flag is set when NBYTES data are transferred, stretching SCL low.

**1: Automatic end mode:** a STOP condition is automatically sent when NBYTES data are transferred.

*Note: This bit has no effect in slave mode or when the RELOAD bit is set.*

Bits 23:16 **NBYTES[7:0]**: Number of bytes

The number of bytes to be transmitted/received is programmed there. This field is don't care in slave mode with SBC=0.

*Note: Changing these bits when the START bit is set is not allowed.*



### 30.7.2 Control register 2 (I2C\_CR2)

Address offset: 0x04

Reset value: 0x0000 0000

Access: No wait states, except if a write access occurs while a write access to this register is ongoing. In this case, wait states are inserted in the second write access until the previous one is completed. The latency of the second write access can be up to 2 x PCLK1 + 6 x I2CCLK.

| 31   | 30   | 29    | 28          | 27    | 26          | 25          | 24         | 23          | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------|-------|-------------|-------|-------------|-------------|------------|-------------|----|----|----|----|----|----|----|
| Res. | Res. | Res.  | Res.        | Res.  | PEC<br>BYTE | AUTO<br>END | RE<br>LOAD | NBYTES[7:0] |    |    |    |    |    |    |    |
|      |      |       |             |       | rs          | rw          | rw         | rw          |    |    |    |    |    |    |    |
| 15   | 14   | 13    | 12          | 11    | 10          | 9           | 8          | 7           | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| NACK | STOP | START | HEAD<br>10R | ADD10 | RD_<br>WRN  | SADD[9:0]   |            |             |    |    |    |    |    |    |    |
| rs   | rs   | rs    | rw          | rw    | rw          | rw          |            |             |    |    |    |    |    |    |    |

Bit 11 ADD10: 10-bit addressing mode (master mode)

0: The master operates in 7-bit addressing mode,

1: The master operates in 10-bit addressing mode

Note: Changing this bit when the START bit is set is not allowed.

```
// Use 7-bit addresses
I2C2->CR2 &= I2C_CR2_ADD10; //Modo maestro receptor, solo recibe 7 de 10 bits de comunicación
// Enable auto-end mode
I2C2->CR2 |= I2C_CR2_AUTOEND; //autofinalización activada
```



### 30.7.1 Control register 1 (I2C\_CR1)

Address offset: 0x00

Reset value: 0x0000 0000

```
// Disable the analog filter
I2C2->CR1 |= I2C_CR1_ANFOFF; //filtro de ruido desactivado
// Disable NOSTRETCH
I2C2->CR1 |= I2C_CR1_NOSTRETCH; //nostretch desactivado
```

Access: No wait states, except if a write access occurs while a write access to this register is ongoing. In this case, wait states are inserted in the second write access until the previous one is completed. The latency of the second write access can be up to 2 x PCLK1 + 6 x I2CCLK.

|          |          |      |         |      |      |      |       |          |         |         |         |      |           |     |    |
|----------|----------|------|---------|------|------|------|-------|----------|---------|---------|---------|------|-----------|-----|----|
| 31       | 30       | 29   | 28      | 27   | 26   | 25   | 24    | 23       | 22      | 21      | 20      | 19   | 18        | 17  | 16 |
| Res.     | Res.     | Res. | Res.    | Res. | Res. | Res. | PECEN | ALERT EN | SMBD EN | SMBH EN | GCEN    | Res. | NOSTRETCH | SBC |    |
|          |          |      |         |      |      |      | rw    | rw       | rw      | rw      | rw      |      | rw        | rw  |    |
| 15       | 14       | 13   | 12      | 11   | 10   | 9    | 8     | 7        | 6       | 5       | 4       | 3    | 2         | 1   | 0  |
| RXDMA EN | TXDMA EN | Res. | ANF OFF | DNF  |      |      | ERRIE | TCIE     | STOP IE | NACK IE | ADDR IE | RXIE | TXIE      | PE  |    |
| rw       | rw       |      | rw      | rw   |      |      | rw    | rw       | rw      | rw      | rw      | rw   | rw        | rw  |    |

#### Bit 17 **NOSTRETCH**: Clock stretching disable

This bit is used to disable clock stretching in slave mode. It must be kept cleared in master mode.

0: Clock stretching enabled

1: Clock stretching disabled

*Note: This bit can only be programmed when the I2C is disabled (PE = 0).*

#### Bit 12 **ANFOFF**: Analog noise filter OFF

0: Analog noise filter enabled

1: Analog noise filter disabled

*Note: This bit can only be programmed when the I2C is disabled (PE = 0).*



```
// Enable the I2Cx peripheral
I2C2->CR1 |= I2C_CR1_PE; //habilita SCL y SDA para el periferico
```

### 30.7.1 Control register 1 (I2C\_CR1)

Address offset: 0x00

Reset value: 0x0000 0000

Access: No wait states, except if a write access occurs while a write access to this register is ongoing. In this case, wait states are inserted in the second write access until the previous one is completed. The latency of the second write access can be up to 2 x PCLK1 + 6 x I2CCLK.

| 31       | 30       | 29   | 28      | 27   | 26   | 25   | 24   | 23    | 22       | 21      | 20      | 19      | 18   | 17        | 16  |
|----------|----------|------|---------|------|------|------|------|-------|----------|---------|---------|---------|------|-----------|-----|
| Res.     | Res.     | Res. | Res.    | Res. | Res. | Res. | Res. | PECEN | ALERT EN | SMBD EN | SMBH EN | GCEN    | Res. | NOSTRETCH | SBC |
|          |          |      |         |      |      |      |      | rw    | rw       | rw      | rw      | rw      |      | rw        | rw  |
| 15       | 14       | 13   | 12      | 11   | 10   | 9    | 8    | 7     | 6        | 5       | 4       | 3       | 2    | 1         | 0   |
| RXDMA EN | TXDMA EN | Res. | ANF OFF | DNF  |      |      |      | ERRIE | TCIE     | STOP IE | NACK IE | ADDR IE | RXIE | TXIE      | PE  |
| rw       | rw       |      | rw      | rw   |      |      |      | rw    | rw       | rw      | rw      | rw      | rw   | rw        | rw  |

Bit 0 **PE**: Peripheral enable

0: Peripheral disable

1: Peripheral enable

Note: When PE=0, the I2C SCL and SDA lines are released. Internal state machines and status bits are put back to their reset value. When cleared, PE must be kept low for at least 3 APB clock cycles.



### 30.7.7 Interrupt and status register (I2C\_ISR)

Address offset: 0x18

Reset value: 0x0000 0001

Access: No wait states

| 31   | 30   | 29    | 28       | 27      | 26   | 25   | 24   | 23            | 22 | 21    | 20    | 19   | 18   | 17   | 16  |     |
|------|------|-------|----------|---------|------|------|------|---------------|----|-------|-------|------|------|------|-----|-----|
| Res. | Res. | Res.  | Res.     | Res.    | Res. | Res. | Res. | ADD CODE[6:0] |    |       |       |      |      |      |     | DIR |
|      |      |       |          |         |      |      |      | r             |    |       |       |      |      |      |     | r   |
| 15   | 14   | 13    | 12       | 11      | 10   | 9    | 8    | 7             | 6  | 5     | 4     | 3    | 2    | 1    | 0   |     |
| BUSY | Res. | ALERT | TIME OUT | PEC ERR | OVR  | ARLO | BERR | TCR           | TC | STOPF | NACKF | ADDR | RXNE | TXIS | TXE |     |
| r    |      | r     | r        | r       | r    | r    | r    | r             | r  | r     | r     | r    | r    | rs   | rs  |     |

#### Bit 1 TXIS: Transmit interrupt status (transmitters)

This bit is set by hardware when the I2C\_TXDR register is empty and the data to be transmitted must be written in the I2C\_TXDR register. It is cleared when the next data to be sent is written in the I2C\_TXDR register.

This bit can be written to '1' by software when NOSTRETCH=1 only, in order to generate a TXIS event (interrupt if TXIE=1 or DMA request if TXDMAEN=1).

*Note: This bit is cleared by hardware when PE=0.*

#### Bit 0 TXE: Transmit data register empty (transmitters)

This bit is set by hardware when the I2C\_TXDR register is empty. It is cleared when the next data to be sent is written in the I2C\_TXDR register.

This bit can be written to '1' by software in order to flush the transmit data register I2C\_TXDR.

*Note: This bit is set by hardware when PE=0.*

#### Bit 5 STOPF: Stop detection flag

This flag is set by hardware when a Stop condition is detected on the bus and the peripheral is involved in this transfer:

- either as a master, provided that the STOP condition is generated by the peripheral.
- or as a slave, provided that the peripheral has been addressed previously during this transfer.

*It is cleared by software by setting the STOPCF bit.*

*Note: This bit is cleared by hardware when PE=0.*

```

void I2C2_Write (char Dat){
  //I2C2 Initialization
  I2C2->CR2 |= (1UL << 13); //bit de START bit 13
  while (!(I2C2->ISR & I2C_ISR_TXIS));
  I2C2->TXDR = LCD I2C Address;
  while !(I2C2->ISR & I2C_ISR_TXIS);
  I2C2->TXDR = Dat;
  while !(I2C2->ISR & I2C_ISR_TXE));
  while !(I2C2->ISR & I2C_ISR_STOPF));
  I2C2->ISR &= ~I2C_ISR_STOPF;
}

```



# Función para recibir un dato por el modulo de I2C:

```
//FUNCION PARA RECIBIR
char I2C2_Read (char Adr){

    I2C2->CR2 |= (1UL<<13); //bit de Start
    while (!(I2C2->ISR & I2C_ISR_TXIS));
    I2C2->TXDR = Adr;
    while (!(I2C2->ISR & I2C_ISR_TXE));
    while (!(I2C2->ISR & I2C_ISR_STOPF));
    I2C2->ISR &= ~I2C_ISR_STOPF;
    I2C2->CR2=0;

    return (Dato);
}
```



## EJEMPLO

```
#include "stm32f7xx.h"
#include "math.h"
//A MANERA GENERAL, LA TARJETA ESTÁ TRABAJANDO COMO MAESTRO EN LA COMUNICACIÓN
//PF1->SCL
//PF0->SDA
int sa[]={0x01,0x2,0x4,0x8,0x10,0x20,0x40,0x80}; //2
int co[]={0x40,0x100,0x200,0x400,0x800,0x1000,0x2000,0x8000}; //puerto comun
char dat[]={0,0,0};
char dal;
int xl=0,yl=0;
int t1,t2,t3,t4,t5,t6,cont=0,su=0;
int a=0,b=0,c=0,d=0,e=0,f=0,g=0,h=0;

static void SystemClock_Config(void);
void SystemIn(void);
//void ConfigSerial(void);
long double CTX, CTY, CTZ;
int Status2, Status4, Dato;
long i=0;
int Reg;
int8_t X1,X2,Y1,Y2,Z1,Z2;
uint8_t b2;
short TX,TY,TZ; //TOTAL X, TOTAL Y, TOTAL Z
uint16_t XS, YS, ZS;
char data;
```



```

void I2C2_Init (void)  {
    RCC->AHB1ENR |= 0x00000020; // Encender reloj puertoF
    GPIOF->AFR[0] |= 0x00000044; // seleccion de la funcion alterna 4 del puerto F(I2C) para PF1-SCL,PF0-SDA -> I2C2
    GPIOF->MODER |= 0x0000000A; // PF0,PF1 => en modo alterno
    GPIOF->OTYPER |= 0x0003; // Open drain
    GPIOF->PUPDR |= 0x5;
    GPIOF->OSPEEDR |= 0xC;

    RCC->APB1ENR |= 0x00400000; // Enable clock for I2C2 bit 22
    RCC->DCKCFGR2 |= 0x80000; //Reloj de frecuencia del I2C2

    // Disable the I2Cx peripheral
    I2C2->CR1 &= ~I2C_CR1_PE; //deshabilita SCL y SDA para el periferico
    while (I2C2->CR1 & I2C_CR1_PE);
    // Set timings. Asuming I2CCLK is 50 MHz (APB1 clock source)
    //I2C2->TIMINGR = 0x40912732; // Discovery BSP code from ST examples
    I2C2->TIMINGR |= 0x30420F13; //I2C2 Timing config at t2clk=1/FHSI
    // Use 7-bit addresses
    I2C2->CR2 &= I2C_CR2_ADD10; //Modo maestro receptor, solo recibe 7 de 10 bits de comunicación
    // Enable auto-end mode
    I2C2->CR2 |= I2C_CR2_AUTOEND; //autofinalización activada
    // Disable the analog filter
    I2C2->CR1 |= I2C_CR1_ANFOFF; //filtro de ruido desactivado
    // Disable NOSTRETCH
    I2C2->CR1 |= I2C_CR1_NOSTRETCH; //nostretch desactivado
    // Enable the I2Cx peripheral
    I2C2->CR1 |= I2C_CR1_PE; //habilita SCL y SDA para el periferico
}

```



```
//FUNCION PARA ENVIAR

void I2C2_Write (char Adr, char Dat){
    //I2C2 Initialization
    //ESTE ES EL ORIGINAL 0x0202203C Y SE CAMBIO POR 0x02022025 PERO PUEDE QUE SEA 0x020220D0
    I2C2->CR2 |= 0x020220D0;
    while (!(I2C2->ISR & I2C_ISR_TXIS));
    I2C2->TXDR = Adr;
    while !(I2C2->ISR & I2C_ISR_TXIS);
    I2C2->TXDR = Dat;
    while !(I2C2->ISR & I2C_ISR_TXE));
    while !(I2C2->ISR & I2C_ISR_STOPF));
    I2C2->ISR &= ~I2C_ISR_STOPF;
}
```



```

void I2C2_Lectura(void){
    //REGISTROS EN CONFIGURACION PARA EL GIROSCOPIO
    for (i=0; i<10000; i++); //OJO -> i=0; i<30000; i++
    X1 = I2C2_Read(0x3B); //CAMBIAR 0X03, POR EL REGISTRO MSB EN X DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);
    X2 = I2C2_Read(0x3C); //CAMBIAR 0X04, POR EL REGISTRO LSB EN X DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);
    Y1 = I2C2_Read(0x3D); //CAMBIAR 0X07, POR EL REGISTRO MSB EN Y DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);
    Y2 = I2C2_Read(0x3E); //CAMBIAR 0X08, POR EL REGISTRO LSB EN Y DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);
    Z1 = I2C2_Read(0x3F); //CAMBIAR 0X05, POR EL REGISTRO MSB EN Z DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);
    Z2 = I2C2_Read(0x40); //CAMBIAR 0X06, POR EL REGISTRO LSB EN Z DEL MPU6050 -> CAMBIAR POR ACELEROMETRO
    for (i=0; i<10000; i++);

    TX=X1;
    TY=Y1;
    TZ=Z1;
}

void Data_PromptX(void){

    XS = (uint16_t)TX;
    xl=((TX*8)/90)+2;
    GPIOD->ODR = 0xFFFF;
    GPIOD->ODR &=~ sa[xl];
}

```



```

int main ()  {

    RCC->AHB1ENR |= 0x1A;
    GPIOD->MODER |=0X5555;
    GPIOB->MODER |=0X45551000;

    SystemIn();
    SystemClock_Config();

    I2C2_Init();                      // initialize I2C2 block
    RCC->AHB1ENR |= 0x3F;      // Enable clock for GPIOD
    GPIOD->MODER |= 0x55555555;

    I2C2_Write(0x6B,0x00);        //LECTURAS
    for (i=0; i<10000; i++) {};
    I2C2_Write(0x1B,0x00);        //CONFIG_GYRO
    for (i=0; i<10000; i++) {};
    I2C2_Write(0x1C,0x00);        //CONFIG_ACELE
    for (i=0; i<10000; i++) {};

    while(1) {

        I2C2_Lectura();
        Data_PromptX();
        Data_PromptY();
        for (i=0; i<10000; i++) {}; // tiempo de mas o menos 100ms
    }
}

```



```

static void SystemClock_Config(void)
{
    RCC->CR |= ((uint32_t)RCC_CR_HSION);                                /* Enable HSI */
    while ((RCC->CR & RCC_CR_HSIRDY) == 0);                            /* Wait for HSI Ready */

    RCC->CFGR = RCC_CFGR_SW_HSI;                                         /* HSI is system clock */
    while ((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_HSI);           /* Wait for HSI used as system clock */
    RCC->CFGR |= (RCC_CFGR_HPRE_DIV1 |                                     /* HCLK = SYSCLK */
                  RCC_CFGR_PPRE1_DIV1 |                                     /* APB1 = HCLK/2 */
                  RCC_CFGR_PPRE2_DIV1 );                                    /* APB2 = HCLK/1 */
    RCC->CR &= ~RCC_CR_PLLON;                                            /* Disable PLL */
}

void SystemIn(void){
    int a=0;
    RCC->CR |= 0x10000;
    while((RCC->CR & 0x20000)==0);
    RCC->APB1ENR = 0x10080000;
    RCC->CFGR = 0x00009400;
    RCC->PLLCFGR = 0x07405408;
    RCC->CR |= 0x01000000;
    while((RCC->CR & 0x02000000)==0);
    FLASH->ACR = (0x00000605);
    RCC->CFGR |= 2;
    for (a=0;a<=500;a++);
}

```



# SENSOR MPU6050

EL MPU6050 es una unidad de medición IMU de 6 grados de libertad pues combina un acelerómetro de 3 ejes y un giroscopio de 3 ejes. Este sensor es muy utilizado en navegación, ya que con él es posible realizar distintas mediciones como goniometría, estabilización, temperatura. Es un sensor de movimiento, que tiene un conversor ADC de 16 bits que convierte los datos a un valor digital, el módulo se comunica a través de la comunicación serie I2C a través del reloj serial (SCL) y datos (SDA).

Necesita 3.3V pero un regulador de voltaje en la tarjeta GY-521 le permite alimentarlo hasta 5V.

Como la comunicación del módulo es vía I2C, esto le permite trabajar con la mayoría de microcontroladores. En el módulo los pines SCL y SDA tienen una resistencia pull-up en la placa para una conexión directa al microcontrolador que estemos utilizando. Las características adicionales incluyen un oscilador en chip con una variación de  $\pm 1\%$  sobre el rango de temperatura de funcionamiento.



### 6.3 Electrical and Other Common Specifications

VDD = 2.375V-3.46V, VLOGIC (MPU-6050 only) = 1.8V $\pm$ 5% or VDD, T<sub>A</sub> = 25°C

| PARAMETER                            | CONDITIONS                                                                   | MIN   | TYP        | MAX  | Units  | Notes |
|--------------------------------------|------------------------------------------------------------------------------|-------|------------|------|--------|-------|
| <b>TEMPERATURE SENSOR</b>            |                                                                              |       |            |      |        |       |
| Range                                | Untrimmed                                                                    |       | -40 to +85 |      | °C     |       |
| Sensitivity                          |                                                                              |       | 340        |      | LSB/°C |       |
| Temperature Offset                   | 35°C                                                                         |       | -521       |      | LSB    |       |
| Linearity                            | Best fit straight line (-40°C to +85°C)                                      |       | $\pm 1$    |      | °C     |       |
| <b>VDD POWER SUPPLY</b>              |                                                                              | 2.375 |            | 3.46 | V      |       |
| Operating Voltages                   |                                                                              |       |            |      |        |       |
| Normal Operating Current             | Gyroscope + Accelerometer + DMP                                              |       | 3.9        |      | mA     |       |
|                                      | Gyroscope + Accelerometer (DMP disabled)                                     |       | 3.8        |      | mA     |       |
|                                      | Gyroscope + DMP (Accelerometer disabled)                                     |       | 3.7        |      | mA     |       |
|                                      | Gyroscope only (DMP & Accelerometer disabled)                                |       | 3.6        |      | mA     |       |
|                                      | Accelerometer only (DMP & Gyroscope disabled)                                | 500   |            |      | μA     |       |
| Accelerometer Low Power Mode Current | 1.25 Hz update rate                                                          |       | 10         |      | μA     |       |
|                                      | 5 Hz update rate                                                             |       | 20         |      | μA     |       |
|                                      | 20 Hz update rate                                                            |       | 70         |      | μA     |       |
|                                      | 40 Hz update rate                                                            |       | 140        |      | μA     |       |
| Full-Chip Idle Mode Supply Current   |                                                                              |       | 5          |      | μA     |       |
| Power Supply Ramp Rate               | Monotonic ramp. Ramp rate is 10% to 90% of the final value                   |       |            | 100  | ms     |       |
| <b>VLOGIC REFERENCE VOLTAGE</b>      |                                                                              |       |            |      |        |       |
| Voltage Range                        | MPU-6050 only                                                                |       |            |      | V      |       |
| Power Supply Ramp Rate               | VLOGIC must be $\leq$ VDD at all times                                       | 1.71  |            | VDD  |        |       |
| Normal Operating Current             | Monotonic ramp. Ramp rate is 10% to 90% of the final value                   |       | 100        | 3    | ms     |       |
| <b>TEMPERATURE RANGE</b>             |                                                                              |       |            |      | μA     |       |
| Specified Temperature Range          | Performance parameters are not applicable beyond Specified Temperature Range | -40   |            | +85  | °C     |       |



# SENSOR MPU6050

Los datos dentro del conjunto de registros internos de los sensores siempre se actualizan a la frecuencia de muestreo. Mientras tanto, el conjunto de registros de lectura orientados al usuario duplica los valores de datos del conjunto de registros internos. Esto garantiza que una lectura de ráfaga de los registros del sensor leerá las mediciones al mismo instante de muestreo. Cada medición es de 16 bits una escala definida.

**Las mediciones de temperatura se escriben en estos registros a la frecuencia de muestreo como se define en el Registro 25.**

**Registro 25 - Divisor de frecuencia de muestreo SMPLRT\_DIV**

| Register (Hex) | Register (Decimal) | Bit7 | Bit6 | Bit5 | Bit4            | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------|--------------------|------|------|------|-----------------|------|------|------|------|
| 19             | 25                 |      |      |      | SMPLRT_DIV[7:0] |      |      |      |      |

Este registro especifica el divisor de la velocidad de salida del sensor utilizado para generar la frecuencia de muestreo para el MPU-60X0.

La frecuencia de muestreo se genera dividiendo la frecuencia de salida del sensor por SMPLRT\_DIV:

$$\text{Frecuencia de muestreo} = \text{Velocidad de salida del sensor} / (1 + \text{SMPLRT\_DIV})$$



# SENSOR MPU6050

donde la velocidad de salida del sensor = 8kHz cuando el DLPF está deshabilitado (DLPF\_CFG = 0 o 7), y 1kHz cuando el DLPF está habilitado

| Register (Hex) | Register (Decimal) | Bit7 | Bit6 | Bit5              | Bit4 | Bit3          | Bit2 | Bit1 | Bit0 |
|----------------|--------------------|------|------|-------------------|------|---------------|------|------|------|
| 1A             | 26                 | -    | -    | EXT_SYNC_SET[2:0] |      | DLPF_CFG[2:0] |      |      |      |

Registros 65 y 66 - Medición de temperatura TEMP\_OUT\_H y TEMP\_OUT\_L

Tipo: solo lectura:

| Register (Hex) | Register (Decimal) | Bit7 | Bit6 | Bit5 | Bit4           | Bit3 | Bit2 | Bit1 | Bit0 |
|----------------|--------------------|------|------|------|----------------|------|------|------|------|
| 41             | 65                 |      |      |      | TEMP_OUT[15:8] |      |      |      |      |
| 42             | 66                 |      |      |      | TEMP_OUT[7:0]  |      |      |      |      |

La temperatura en grados C para un valor de registro dado se puede calcular como:

$$\text{Temperatura } ^\circ\text{C} = (\text{Valor de registro TEMP_OUT}) / 340 + 36.53$$

"Tenga en cuenta que las matemáticas en la ecuación anterior están en decimal."



# SENSOR MPU6050

## Registros 104 – Signal Path Reset SIGNAL\_PATH\_RESET

Este registro se utiliza para restablecer las rutas de señal analógica y digital de los sensores de giroscopio, acelerómetro y temperatura.

El reinicio revertirá la ruta de señal de los convertidores y filtros analógicos a digitales a sus configuraciones de encendido.

"Este registro no borra los registros del sensor." Los bits 7 a 3 están reservados.

| Register (Hex) | Register (Decimal) | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2       | Bit1        | Bit0       |
|----------------|--------------------|------|------|------|------|------|------------|-------------|------------|
| 68             | 104                | -    | -    | -    | -    | -    | GYRO_RESET | ACCEL_RESET | TEMP_RESET |

**GYRO\_RESET:** cuando se establece en 1, este bit restablece las rutas de señal digital y analógica del giroscopio.

**ACCEL\_RESET:** cuando se establece en 1, este bit restablece las rutas de señal analógica y digital del acelerómetro.

**TEMP\_RESET:** cuando se establece en 1, este bit restablece las rutas de señal analógica y digital del sensor de temperatura.



```

1 #include "stm32f7xx.h"
2 #include "math.h"
3 #include "lcd.c"
4
5 //A MANERA GENERAL, LA TARJETA ESTÁ TRABAJANDO COMO MAESTRO EN LA COMUNICACIÓN
6 //PF1->SCL
7 //PF0->SDA
8 char dat[]={0,0,0};
9 float templ=0;
10 int temp2=0;
11 int unidades;
12 int miles;
13 int centenas;
14 int decenas;
15 int a=0,b=0,c=0;
16
17 static void SystemClock_Config(void);
18 void SystemIn(void);
19 //void ConfigSerial(void);
20 int Dato;
21 long i=0;
22 int8_t T1,T2;
23 //float T1;
24 short TT; //TOTAL Temperatura
25 int16_t TS;
26 char data;
27
28 int vec[5]={84,101,109,112,58};
29 void I2C2_Init (void) {
30     RCC->AHB1ENR |= 0x00000020; // Encender reloj puertoF
31     GPIOF->AFR[0] |= 0x00000044; // seleccion de la funcion alterna 4 del puerto F(I2C) para PF1-SCL,PF0-SDA -> I2C2
32     GPIOF->MODER |= 0x0000000A; // PF0,PF1 => en modo alterno
33     GPIOF->OTYPER |= 0x0003;    // Open drain

```



```

34     GPIOF->PUPDR |= 0x5;
35     GPIOF->OSPEEDR |= 0xC;
36
37     RCC->APB1ENR |= 0x00400000;           // Enable clock for I2C2 bit 22
38     RCC->DCKCFGR2 |= 0x80000;             //Reloj de frecuencia del I2C2
39
40     // Disable the I2Cx peripheral
41     I2C2->CR1 &= ~I2C_CR1_PE; //deshabilita SCL y SDA para el periferico
42     while (I2C2->CR1 & I2C_CR1_PE);
43     // Set timings. Asuming I2CCLK is 50 MHz (APB1 clock source)
44     //I2C2->TIMINGR = 0x40912732;          // Discovery BSP code from ST examples
45     I2C2->TIMINGR |= 0x30420F13;           //I2C2 Timing config at t2clk=1/FHSI
46     // Use 7-bit addresses
47     I2C2->CR2 &=~ I2C_CR2_ADD10; //Modo maestro receptor, solo recibe 7 de 10 bits de comunicación
48     // Enable auto-end mode
49     I2C2->CR2 |= I2C_CR2_AUTOEND; //autofinalización activada
50     // Disable the analog filter
51     I2C2->CR1 |= I2C_CR1_ANFOFF; //filtro de ruido desactivado
52     // Disable NOSTRETCH
53     I2C2->CR1 |= I2C_CR1_NOSTRETCH; //nostretch desactivado
54     // Enable the I2Cx peripheral
55     I2C2->CR1 |= I2C_CR1_PE; //habilita SCL y SDA para el periferico
56 }
57
58 //FUNCION PARA ENVIAR
59
60 void I2C2_Write (char Adr, char Dat){
61 //I2C2 Initialization
62     //ESTE ES EL ORIGINAL 0x0202203C Y SE CAMBIO POR 0x02022025 PERO PUEDE QUE SEA 0x020220D0
63     I2C2->CR2 |= 0x020220D0;
64     while (!(I2C2->ISR & I2C_ISR_TXIS));
65     I2C2->TXDR = Adr;
66     while (!(I2C2->ISR & I2C_ISR_TXIS));
67     I2C2->TXDR = Dat;

```



```

67     I2C2->TXDR = Dat;
68     while (! (I2C2->ISR & I2C_ISR_TXE));
69     while (! (I2C2->ISR & I2C_ISR_STOPF));
70     I2C2->ISR &= ~I2C_ISR_STOPF;
71 }
72
73 //FUNCION PARA RECIBIR
74 int8_t I2C2_Read (char Adr){ // procedure: RM0090, pg. 584!
75     //ESTE ES EL ORIGINAL 0x0201203C; Y SE CAMBIO POR 0x02022025 PERO PUEDE QUE SEA 0x020220D0
76     I2C2->CR2 |= 0x020120D0;
77     while (! (I2C2->ISR & I2C_ISR_RXIS));
78     I2C2->TXDR = Adr;
79     while (! (I2C2->ISR & I2C_ISR_TXE));
80     while (! (I2C2->ISR & I2C_ISR_STOPF));
81     I2C2->ISR &= ~I2C_ISR_STOPF;
82     I2C2->CR2=0;
83
84     // Disable the I2Cx peripheral
85     I2C2->CR1 &= ~I2C_CR1_PE;
86     while (I2C2->CR1 & I2C_CR1_PE);
87     // Set timings. Asuming I2CCLK is 50 MHz (APB1 clock source)
88     //I2C2->TIMINGR = 0x40912732;           // Discovery BSP code from ST examples
89     I2C2->TIMINGR |= 0x30420F13;           //I2C2 Timing config at t2clk=1/FHSI
90     // Use 7-bit addresses
91     I2C2->CR2 &=~ I2C_CR2_ADD10;
92     // Enable auto-end mode
93     I2C2->CR2 |= I2C_CR2_AUTOEND;
94     // Disable the analog filter
95     I2C2->CR1 |= I2C_CR1_ANFOFF;
96     // Disable NOSTRETCH
97     I2C2->CR1 |= I2C_CR1_NOSTRETCH;
98     // Enable the I2Cx peripheral
99     I2C2->CR1 |= I2C_CR1_PE;

```



```

101 //ESTE ES EL ORIGINAL 0x0201243C; Y SE CAMBIO POR 0x02022025 PERO PUEDE QUE SEA 0x020220D0
102 I2C2->CR2 |= 0x020124D1;
103 while (!(I2C2->ISR & I2C_ISR_RXNE));
104 Dato = I2C2->RXDR;
105 while (!(I2C2->ISR & I2C_ISR_STOPF));
106 I2C2->ISR &= ~I2C_ISR_STOPF;
107 I2C2->CR2=0;
108
109 // Disable the I2Cx peripheral
110 I2C2->CR1 &= ~I2C_CR1_PE;
111 while (I2C2->CR1 & I2C_CR1_PE);
112 // Set timings. Asuming I2CCLK is 50 MHz (APB1 clock source)
113 //I2C2->TIMINGR = 0x40912732;           // Discovery BSP code from ST examples
114 I2C2->TIMINGR |= 0x30420F13;           //I2C2 Timing config at t2clk=1/FHSI
115 // Use 7-bit addresses
116 I2C2->CR2 &=~ I2C_CR2_ADD10;
117 // Enable auto-end mode
118 I2C2->CR2 |= I2C_CR2_AUTOEND;
119 // Disable the analog filter
120 I2C2->CR1 |= I2C_CR1_ANFOFF;
121 // Disable NOSTRETCH
122 I2C2->CR1 |= I2C_CR1_NOSTRETCH;
123 // Enable the I2Cx peripheral
124 I2C2->CR1 |= I2C_CR1_PE;
125
126     return (Dato);
127 }
128 void I2C2_Lectura(void){
129     T1 = I2C2_Read(0x41);
130     for (i=0; i<10000; i++) {};
131     T2 = I2C2_Read(0x42);
132     for (i=0; i<10000; i++) {};
133 }
```



```

135           TT=T1*340;
136           //TT=T1;
137     }
138
139   void Temp_Prompt(void){
140
141     TS=(int16_t)TT;
142     templ=((TS/340)+36.53);
143
144     temp2=templ*100;
145
146     miles=temp2/1000;
147     centenas=(temp2-(miles*1000))/100;
148     decenas=(temp2- (miles*1000 + centenas*100))/10;
149     unidades=temp2-(miles*1000 + centenas*100 + decenas*10 );
150
151   |
152 }
153 int main () {
154
155   RCC->AHB1ENR |= 0x1A;
156   GPIOB->MODER |=0X45551000;
157   lcdstart();
158   SystemIn();
159   SystemClock_Config();
160
161   I2C2_Init();           // initialize I2C2 block
162   RCC->AHB1ENR |= 0x3F; // Enable clock for GPIOD
163
164   I2C2_Write(0x6B,0x00);
165   for (i=0; i<10000; i++) {};
166   I2C2_Write(0x68,0x01);
167   for (i=0; i<10000; i++) {};

```



```

164     I2C2_Write(0x6B,0x00);
165     for (i=0; i<10000; i++) {};
166     I2C2_Write(0x68,0x01);
167     for (i=0; i<10000; i++) {};
168
169     frase(vec,5);
170
171     while(1) {
172
173         I2C2_Lectura();
174         Temp_Prompt();
175
176         for (i=0; i<10000; i++) {}; // tiempo de mas o menos 100ms
177
178         posd(2);
179         numero(miles);
180         numero(centenas);
181         letra(46);
182         numero(decenas);
183         numero(unidades);
184         letra(67);
185
186     }
187 }
188
189

```

