打印
[应用相关]

STM32之MPU6050获取欧拉角

[复制链接]
手机看帖
扫描二维码
随时随地手机跟帖
21
发顺丰更大nc|  楼主 | 2023-12-28 16:08 | 只看该作者 |只看大图 回帖奖励 |倒序浏览
FIFO使能寄存器 控制mpu6050的加速度计、温度传感器、陀螺仪的原始数据是否写入FIFO缓冲区。

TEMP_FIFO_EN 位用于控制是否将温度传感器的原始数据写入FIFO缓冲区,设置为 1,写入FIFO缓冲区。
XG_ FIFO_EN 位用于控制是否将陀螺仪X轴的原始数据写入FIFO缓冲区,设置为 1,写入FIFO缓冲区。
YG_ FIFO_EN 位用于控制是否将陀螺仪Y轴的原始数据写入FIFO缓冲区,设置为 1,写入FIFO缓冲区。
ZG_ FIFO_EN 位用于控制是否将陀螺仪Z轴的原始数据写入FIFO缓冲区,设置为 1,写入FIFO缓冲区。
ACCEL_ FIFO_EN 位用于控制是否将加速度计的原始数据写入FIFO缓冲区,设置为 1,写入FIFO缓冲区。
其他位不用管,设置为0。

使用特权

评论回复
22
发顺丰更大nc|  楼主 | 2023-12-28 16:08 | 只看该作者
我是谁寄存器

存储 mpu6050 的7位I2C地址的高6位,用来验证设备的身份。

该寄存器的默认值为0x68(即 b0 110100 0)。
mpu6050 的 Slave 地址为 b110100X,7 位字长,最低有效位 X 由 AD0 引脚上的逻辑电平决定,高电平为1,低电平为0。

使用特权

评论回复
23
发顺丰更大nc|  楼主 | 2023-12-28 16:09 | 只看该作者
MPU6050通信协议
当连接到系统芯片时,mpu6050 总是作为从设备,因此,系统芯片可以通过 400kHz 的 I2C 接口来操作 mpu6050 的内部寄存器。mpu6050 的 Slave 地址为 b110100X,7 位字长,最低有效位 X 由 AD0 引脚上的逻辑电平决定,高电平为1,低电平为0(即高电平时 mpu6050 从机地址为0x69,低电平时 mpu6050 从机地址为0x68)。

使用特权

评论回复
24
发顺丰更大nc|  楼主 | 2023-12-28 16:09 | 只看该作者
MPU6050写入寄存器时序
单字节写入时序:

使用特权

评论回复
25
发顺丰更大nc|  楼主 | 2023-12-28 16:09 | 只看该作者
多字节写入时序:

使用特权

评论回复
26
发顺丰更大nc|  楼主 | 2023-12-28 16:09 | 只看该作者
①:主设备发送起始信号。
②:主设备发送7位mpu6050的I2C设备地址以及一个W 位,即0 。
③:主设备等待从设备(mpu6050)发送应答信号。
④:主设备发送想要写入寄存器的地址。
⑤:主设备等待从设备(mpu6050)发送应答信号。
⑥:主设备发送想要写入寄存器的数据。
⑦:主设备等待从设备(mpu6050)发送应答信号。
⑧:主设备发送终止信号。
如果想连续写入寄存器数据则在主设备发送终止信号前重复⑥、⑦步骤即可。

使用特权

评论回复
27
发顺丰更大nc|  楼主 | 2023-12-28 16:10 | 只看该作者
MPU6050寄存器读取时序
单字节读取时序:

使用特权

评论回复
28
发顺丰更大nc|  楼主 | 2023-12-28 16:10 | 只看该作者
多字节读取时序:
①:主设备发送起始信号。
②:主设备发送7位mpu6050的I2C设备地址以及一个W 位,即0 。
③:主设备等待从设备(mpu6050)发送应答信号。
④:主设备发送想要写入寄存器的地址。
⑤:主设备等待从设备(mpu6050)发送应答信号。
⑥:主设备发送起始信号。
⑦:主设备发送7位mpu6050的I2C设备地址以及一个R 位,即1 。
⑧:主设备等待从设备(mpu6050)发送应答信号。
⑨:主设备读取想要读取寄存器的数据。
⑩:主设备发送应答信号(可选,多字节读取时序时使用)。
⑪:主设备读取想要读取寄存器的数据(可选,多字节读取时序时使用)。
⑫:主设备发送非应答信号。
⑬:主设备发送终止信号。
如果想连续读取寄存器数据则在主设备发送非应答信号和终止信号前重复⑩、⑪步骤即可。

使用特权

评论回复
29
发顺丰更大nc|  楼主 | 2023-12-28 16:10 | 只看该作者
MPU6050获取三轴加速度、三轴陀螺仪以及温度
MPU6050与STM32板子接线
PB6 <-> SCL
PB7 <-> SDA
单片机5V <-> VCC
GND <-> GND
AD0 <-> GND

使用特权

评论回复
30
发顺丰更大nc|  楼主 | 2023-12-28 16:10 | 只看该作者
STM32CubeMX相关配置
配置SYS

使用特权

评论回复
31
发顺丰更大nc|  楼主 | 2023-12-28 16:11 | 只看该作者
配置RCC

使用特权

评论回复
32
发顺丰更大nc|  楼主 | 2023-12-28 16:11 | 只看该作者
配置USART3

使用特权

评论回复
33
发顺丰更大nc|  楼主 | 2023-12-28 16:11 | 只看该作者
配置NVIC

使用特权

评论回复
34
发顺丰更大nc|  楼主 | 2023-12-28 16:11 | 只看该作者
使用Micro库
只要映射了printf用来发送数据去串口都要使用这个库。

使用特权

评论回复
35
发顺丰更大nc|  楼主 | 2023-12-28 16:11 | 只看该作者
文件编写
修改文件usart.c
/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * [url=home.php?mod=space&uid=288409]@file[/url]    usart.c
  * [url=home.php?mod=space&uid=247401]@brief[/url]   This file provides code for the configuration
  *          of the USART instances.
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2023 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "usart.h"

/* USER CODE BEGIN 0 */

#include <stdio.h>
#include <string.h>

#define USART_REC_LEN 200

// 串口接收缓存(1字节)
uint8_t buf = 0;

uint8_t UART1_RX_Buffer[USART_REC_LEN]; // 接收缓冲,串口接收的数据存放地点

// 串口接收状态,16位
uint16_t UART1_RX_STA = 0;
// bit15: 如果是1表示接收完成
// bit14: 如果是1表示接收到回车(0x0d)
// bit13~bit0: 接收到的有效字节数目


/* USER CODE END 0 */

UART_HandleTypeDef huart3;

/* USART3 init function */

void MX_USART3_UART_Init(void)
{

  /* USER CODE BEGIN USART3_Init 0 */

  /* USER CODE END USART3_Init 0 */

  /* USER CODE BEGIN USART3_Init 1 */

  /* USER CODE END USART3_Init 1 */
  huart3.Instance = USART3;
  huart3.Init.BaudRate = 115200;
  huart3.Init.WordLength = UART_WORDLENGTH_8B;
  huart3.Init.StopBits = UART_STOPBITS_1;
  huart3.Init.Parity = UART_PARITY_NONE;
  huart3.Init.Mode = UART_MODE_TX_RX;
  huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart3) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN USART3_Init 2 */

        /* 开启串口1的接收中断 */
  HAL_UART_Receive_IT(&huart3, &buf, 1); /* 每接收一个串口数据调用一次串口接收完成回调函数 */
        printf("usart3 is ok\r\n");
       
  /* USER CODE END USART3_Init 2 */

}

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  if(uartHandle->Instance==USART3)
  {
  /* USER CODE BEGIN USART3_MspInit 0 */

  /* USER CODE END USART3_MspInit 0 */
    /* USART3 clock enable */
    __HAL_RCC_USART3_CLK_ENABLE();

    __HAL_RCC_GPIOB_CLK_ENABLE();
    /**USART3 GPIO Configuration
    PB10     ------> USART3_TX
    PB11     ------> USART3_RX
    */
    GPIO_InitStruct.Pin = GPIO_PIN_10;
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

    GPIO_InitStruct.Pin = GPIO_PIN_11;
    GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
    GPIO_InitStruct.Pull = GPIO_NOPULL;
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

    /* USART3 interrupt Init */
    HAL_NVIC_SetPriority(USART3_IRQn, 0, 0);
    HAL_NVIC_EnableIRQ(USART3_IRQn);
  /* USER CODE BEGIN USART3_MspInit 1 */

  /* USER CODE END USART3_MspInit 1 */
  }
}

void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
{

  if(uartHandle->Instance==USART3)
  {
  /* USER CODE BEGIN USART3_MspDeInit 0 */

  /* USER CODE END USART3_MspDeInit 0 */
    /* Peripheral clock disable */
    __HAL_RCC_USART3_CLK_DISABLE();

    /**USART3 GPIO Configuration
    PB10     ------> USART3_TX
    PB11     ------> USART3_RX
    */
    HAL_GPIO_DeInit(GPIOB, GPIO_PIN_10|GPIO_PIN_11);

    /* USART3 interrupt Deinit */
    HAL_NVIC_DisableIRQ(USART3_IRQn);
  /* USER CODE BEGIN USART3_MspDeInit 1 */

  /* USER CODE END USART3_MspDeInit 1 */
  }
}

/* USER CODE BEGIN 1 */

/* 重写stdio.h文件中的prinft()里的fputc()函数 */
int fputc(int my_data, FILE *p)
{
    unsigned char temp = my_data;
    // 改写后,使用printf()函数会将数据通过串口一发送出去
    HAL_UART_Transmit(&huart3, &temp, 1, 0xffff); // 0xfffff为最大超时时间
    return my_data;
}

/* 串口接收完成回调函数 */
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
    // 判断中断是哪个串口触发的
    if (huart->Instance == USART1)
    {

        // 判断接收是否完成,即判断UART1_RX_STA的bit15是否为1
        if (!(UART1_RX_STA & 0x8000))
        { // 如果没接收完成就进入接收流程

            // 判断是否接收到回车0x0d
            if (UART1_RX_STA & 0x4000)
            {

                // 判断是否接收到换行0x0a
                if (buf == 0x0a)
                {

                    // 如果回车和换行都接收到了,则表示接收完成,即把bit15拉高
                    UART1_RX_STA |= 0x8000;
                }
                else
                { // 如果接收到回车0x0d没有接收到换行0x0a

                    // 则认为接收错误,重新开始接收
                    UART1_RX_STA = 0;
                }
            }
            else
            { // 如果没有接收到回车0x0d

                // 则判断收到的这个字符是否是回车0x0d
                if (buf == 0x0d)
                {

                    // 如果这个字符是回车,则将将bit14拉高,表示接收到回车
                    UART1_RX_STA |= 0x4000;
                }
                else
                { // 如果不是回车

                    // 则将这个字符存放到缓存数组中
                    UART1_RX_Buffer[UART1_RX_STA & 0x3ffff] = buf;
                    UART1_RX_STA++;

                    // 如果接收数据大于UART1_REC_LEN(200字节),则重新开始接收
                    if (UART1_RX_STA > USART_REC_LEN - 1)
                    {
                        UART1_RX_STA = 0;
                    }
                }
            }
        }
        // 如果接收完成则重新开启串口1的接收中断
        HAL_UART_Receive_IT(&huart3, &buf, 1);
    }
}

/* 对串口接收数据的处理 */
void usart1_receive_data_handle()
{
    /* 判断判断串口是否接收完成 */
    if (UART1_RX_STA & 0x8000)
    {
        printf("接收完成\r\n");

        // 串口接收完数据后,对串口数据进行处理
        if (!strcmp((const char *)UART1_RX_Buffer, "haozige"))
        {
            printf("浩子哥\r\n");
        }

        // 接收到其他数据,进行报错
        else
        {
                                                printf("%s\r\n", "输入错误,请重新输入");
        }

        // 换行,重新开始下一次接收
        memset(UART1_RX_Buffer, 0, USART_REC_LEN);
        UART1_RX_STA = 0;
    }
}

/* USER CODE END 1 */

使用特权

评论回复
36
发顺丰更大nc|  楼主 | 2023-12-28 16:12 | 只看该作者
修改文件usart.h

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file    usart.h
  * @brief   This file contains all the function prototypes for
  *          the usart.c file
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2023 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Define to prevent recursive inclusion -------------------------------------*/
#ifndef __USART_H__
#define __USART_H__

#ifdef __cplusplus
extern "C" {
#endif

/* Includes ------------------------------------------------------------------*/
#include "main.h"

/* USER CODE BEGIN Includes */

/* USER CODE END Includes */

extern UART_HandleTypeDef huart3;

/* USER CODE BEGIN Private defines */

/* USER CODE END Private defines */

void MX_USART3_UART_Init(void);

/* USER CODE BEGIN Prototypes */

void usart1_receive_data_handle(void);

/* USER CODE END Prototypes */

#ifdef __cplusplus
}
#endif

#endif /* __USART_H__ */


使用特权

评论回复
37
发顺丰更大nc|  楼主 | 2023-12-28 16:12 | 只看该作者
添加文件mpu6050.c

#include "my_i2c.h"
#include "mpu6050.h"
#include "usart.h"
#include <stdio.h>

uint8_t mpu6050_init()
{
        uint8_t id,data;
       
        IIC_gpio_init();
       
        mpu6050_read_len(MPU6050_ADDR,MPU_DEVICE_ID_REG,1,&id);

        if(id == 0x68){

                mpu6050_reset();  /* mpu6050软件复位  0x6B */
               
                mpu6050_set_rate(100);  /* 设置陀螺仪采样频率为100Hz  0x19 */
               
                mpu6050_set_accelerated_speed(0);  /* 设置加速度量程范围:±2g  0x1C */
               
                mpu6050_set_gyroscope(3);  /* 设置陀螺仪量程范围:±2000dps  0x1B */
               
                /* 关闭所有中断 */
                data = 0;
                mpu6050_write_len(MPU6050_ADDR,MPU_INT_EN_REG,1,&data);
               
                /* 关闭IIC主模式 */
                data = 0;
                mpu6050_write_len(MPU6050_ADDR,MPU_USER_CTRL_REG,1,&data);
               
          /* 关闭FIFO */
                data = 0;
                mpu6050_write_len(MPU6050_ADDR,MPU_FIFO_EN_REG,1,&data);
               
          /* 设置CLKSEL,PLL X轴为参考 */
                data = 0x01;
                mpu6050_write_len(MPU6050_ADDR,MPU_PWR_MGMT1_REG,1,&data);
               
          /* 加速度与陀螺仪都工作 */
                data = 0;
                mpu6050_write_len(MPU6050_ADDR,MPU_PWR_MGMT2_REG,1,&data);
               
                return 0;
               
        }
       
        return 1;
}

/* mpu6050软件复位 */
void mpu6050_reset()
{
        uint8_t data;
        data = 0x80;
        mpu6050_write_len(MPU6050_ADDR,MPU_PWR_MGMT1_REG,1,&data);  // 复位mpu6050
       
        HAL_Delay(100);
       
        data = 0x00;
          // 唤醒mpu6050
}

/* 设置数字低通滤波器频率(陀螺仪输出频率) */
void mpu6050_set_lpf(uint16_t lpf)
{
        // 该函数设置陀螺仪输出频率为1000Hz
        uint8_t data;
        mpu6050_write_len(MPU6050_ADDR,MPU_CFG_REG,1,&data);
}       


/* 设置陀螺仪采样频率:4~1000Hz */
void mpu6050_set_rate(uint16_t rata)
{
        // 陀螺仪采样率rate = 陀螺仪输出频率(1000Hz或8000Hz,mpu6050_set_lpf函数设定为1000Hz) / (SMPLPT_DIV + 1)(采样周期)
        uint8_t data;
        if(rata >= 1000) rata = 1000;
        if(rata <= 4) rata = 4;
       
        data = 1000/rata - 1;
        mpu6050_write_len(MPU6050_ADDR,MPU_SAMPLE_RATE_REG,1,&data);
       
        mpu6050_set_lpf(rata / 2); // 自动设置低通滤波频率为采样率的一半
       
}

/*
设置加速度量程范围:
        data:
                0 --> ±2g
                1 --> ±4g
                2 --> ±8g
                3 --> ±16g
*/
void mpu6050_set_accelerated_speed(uint8_t data)
{
        data <<= 3;
        mpu6050_write_len(MPU6050_ADDR,MPU_ACCEL_CFG_REG,1,&data);
}

/*
设置陀螺仪量程范围:
        fsr:
                0 --> ±250dps
                1 --> ±500dps
                2 --> ±1000dps
                3 --> ±2000dps
*/
void mpu6050_set_gyroscope(uint8_t data)
{
        data <<= 3;
        mpu6050_write_len(MPU6050_ADDR,MPU_GYRO_CFG_REG,1,&data);
}

/* 获取mpu6050的原始数据 */
void mpu6050_read_accelerated_speed(int16_t *accelerated_speed_x,int16_t *accelerated_speed_y,int16_t *accelerated_speed_z)
{
        uint8_t rev_buf[6];
       
        mpu6050_read_len(MPU6050_ADDR,MPU_ACCEL_XOUTH_REG,6,rev_buf);  //读取x,y,z三轴的加速度值
       
        *accelerated_speed_x = (int16_t)(rev_buf[0] << 8 | rev_buf[1]);
        *accelerated_speed_y = (int16_t)(rev_buf[2] << 8 | rev_buf[3]);
        *accelerated_speed_z = (int16_t)(rev_buf[4] << 8 | rev_buf[5]);
}

void mpu6050_read_gyroscope(int16_t *gyroscope_x,int16_t *gyroscope_y,int16_t *gyroscope_z)
{
        uint8_t rev_buf[6];
         
        mpu6050_read_len(MPU6050_ADDR,MPU_GYRO_XOUTH_REG,6,rev_buf);  //读取x,y,z三轴的陀螺仪值
       
        *gyroscope_x = (int16_t)(rev_buf[0] << 8 | rev_buf[1]);
        *gyroscope_y = (int16_t)(rev_buf[2] << 8 | rev_buf[3]);
        *gyroscope_z = (int16_t)(rev_buf[4] << 8 | rev_buf[5]);
}

float mpu6050_read_temperature()
{
        uint8_t rev_buf[2];
        int16_t *temperature;
       
        mpu6050_read_len(MPU6050_ADDR,MPU_TEMP_OUTH_REG,2,rev_buf);
       
        *temperature = (int16_t)(rev_buf[0] << 8 | rev_buf[1]);
        return 36.53 + *temperature / 340;
}


/* 下面两个函数用来代替dmp库中内容 */
uint8_t mpu6050_write_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf)
{
          uint8_t i;
   
    IIC_start();
    IIC_send_byte((addr | 0));
    if (IIC_wait_ack() == 1)
    {
        IIC_stop();
        return 1;
    }
    IIC_send_byte(reg);
    if (IIC_wait_ack() == 1)
    {
        IIC_stop();
        return 1;
    }
    for (i=0; i<len; i++)
    {
        IIC_send_byte(buf[i]);
        if (IIC_wait_ack() == 1)
        {
            IIC_stop();
            return 1;
        }
    }
    IIC_stop();
    return 0;
}

uint8_t mpu6050_read_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf)
{
          IIC_start();
    IIC_send_byte(addr | 0);
    if (IIC_wait_ack() == 1)
    {
        IIC_stop();
        return 1;
    }
    IIC_send_byte(reg);
    if (IIC_wait_ack() == 1)
    {
        IIC_stop();
        return 1;
    }
    IIC_start();
    IIC_send_byte(addr | 1);
    if (IIC_wait_ack() == 1)
    {
        IIC_stop();
        return 1;
    }
    while (len)
    {
        *buf = IIC_read_byte((len > 1) ? 1 : 0);
        len--;
        buf++;
    }
    IIC_stop();
    return 0;
}

使用特权

评论回复
38
发顺丰更大nc|  楼主 | 2023-12-28 16:12 | 只看该作者
添加文件mpu6050.h
#include "main.h"

#define  MPU6050_ADDR  0xD0  //mou6050APD0引脚接地,因此它的I2C地址为0xD0,即0x68 << 2

#define  MPU_DEVICE_ID_REG     0X75         // 器件ID寄存器

#define  MPU_CFG_REG           0X1A  // 配置寄存器
#define  MPU_SAMPLE_RATE_REG   0X19  // 陀螺仪采样率分频寄存器
#define  MPU_GYRO_CFG_REG      0X1B         // 陀螺仪传感器配置寄存器
#define  MPU_ACCEL_CFG_REG     0X1C         // 加速度传感器配置寄存器


#define  MPU_ACCEL_XOUTH_REG   0X3B  // 加速度值,X轴高8位寄存器
#define  MPU_ACCEL_XOUTL_REG   0X3C  // 加速度值,X轴低8位寄存器
#define  MPU_ACCEL_YOUTH_REG   0X3D  // 加速度值,Y轴高8位寄存器
#define  MPU_ACCEL_YOUTL_REG   0X3E  // 加速度值,Y轴低8位寄存器
#define  MPU_ACCEL_ZOUTH_REG   0X3F  // 加速度值,Z轴高8位寄存器
#define  MPU_ACCEL_ZOUTL_REG   0X40  // 加速度值,Z轴低8位寄存器


#define  MPU_TEMP_OUTH_REG     0X41         // 温度值高8位寄存器
#define  MPU_TEMP_OUTL_REG     0X42  // 温度值低8位寄存器


#define  MPU_GYRO_XOUTH_REG    0X43         // 陀螺仪值,X轴高8位寄存器
#define  MPU_GYRO_XOUTL_REG    0X44         // 陀螺仪值,X轴低8位寄存器
#define  MPU_GYRO_YOUTH_REG    0X45         // 陀螺仪值,Y轴高8位寄存器
#define  MPU_GYRO_YOUTL_REG    0X46         // 陀螺仪值,Y轴低8位寄存器
#define  MPU_GYRO_ZOUTH_REG    0X47         // 陀螺仪值,Z轴高8位寄存器
#define  MPU_GYRO_ZOUTL_REG    0X48         // 陀螺仪值,Z轴低8位寄存器


#define  MPU_USER_CTRL_REG     0X6A         // 用户控制寄存器
#define  MPU_PWR_MGMT1_REG     0X6B         // 电源管理寄存器1
#define  MPU_PWR_MGMT2_REG     0X6C         // 电源管理寄存器2


#define  MPU_INTBP_CFG_REG     0X37  // 中断/旁路设置寄存器
#define  MPU_INT_EN_REG        0X38  // 中断使能寄存器
#define  MPU_INT_STA_REG       0X3A  // 中断状态寄存器


#define  MPU_FIFO_EN_REG       0X23         // FIFO使能寄存器
#define  MPU_FIFO_CNTH_REG     0X72         // FIFO计数寄存器高八位
#define  MPU_FIFO_CNTL_REG     0X73         // FIFO计数寄存器低八位
#define  MPU_FIFO_RW_REG       0X74         // FIFO读写寄存器

void mpu6050_reset(void);
uint8_t mpu6050_init(void);
void mpu6050_set_lpf(uint16_t lpf);
void mpu6050_set_rate(uint16_t rata);
void mpu6050_set_accelerated_speed(uint8_t data);
void mpu6050_set_gyroscope(uint8_t data);

void mpu6050_read_accelerated_speed(int16_t *accelerated_speed_x,int16_t *accelerated_speed_y,int16_t *accelerated_speed_z);

void mpu6050_read_gyroscope(int16_t *gyroscope_x,int16_t *gyroscope_y,int16_t *gyroscope_z);

float mpu6050_read_temperature(void);


uint8_t mpu6050_write_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf);
uint8_t mpu6050_read_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf);

使用特权

评论回复
39
发顺丰更大nc|  楼主 | 2023-12-28 16:12 | 只看该作者
添加文件mpu6050.h
#include "main.h"

#define  MPU6050_ADDR  0xD0  //mou6050APD0引脚接地,因此它的I2C地址为0xD0,即0x68 << 2

#define  MPU_DEVICE_ID_REG     0X75         // 器件ID寄存器

#define  MPU_CFG_REG           0X1A  // 配置寄存器
#define  MPU_SAMPLE_RATE_REG   0X19  // 陀螺仪采样率分频寄存器
#define  MPU_GYRO_CFG_REG      0X1B         // 陀螺仪传感器配置寄存器
#define  MPU_ACCEL_CFG_REG     0X1C         // 加速度传感器配置寄存器


#define  MPU_ACCEL_XOUTH_REG   0X3B  // 加速度值,X轴高8位寄存器
#define  MPU_ACCEL_XOUTL_REG   0X3C  // 加速度值,X轴低8位寄存器
#define  MPU_ACCEL_YOUTH_REG   0X3D  // 加速度值,Y轴高8位寄存器
#define  MPU_ACCEL_YOUTL_REG   0X3E  // 加速度值,Y轴低8位寄存器
#define  MPU_ACCEL_ZOUTH_REG   0X3F  // 加速度值,Z轴高8位寄存器
#define  MPU_ACCEL_ZOUTL_REG   0X40  // 加速度值,Z轴低8位寄存器


#define  MPU_TEMP_OUTH_REG     0X41         // 温度值高8位寄存器
#define  MPU_TEMP_OUTL_REG     0X42  // 温度值低8位寄存器


#define  MPU_GYRO_XOUTH_REG    0X43         // 陀螺仪值,X轴高8位寄存器
#define  MPU_GYRO_XOUTL_REG    0X44         // 陀螺仪值,X轴低8位寄存器
#define  MPU_GYRO_YOUTH_REG    0X45         // 陀螺仪值,Y轴高8位寄存器
#define  MPU_GYRO_YOUTL_REG    0X46         // 陀螺仪值,Y轴低8位寄存器
#define  MPU_GYRO_ZOUTH_REG    0X47         // 陀螺仪值,Z轴高8位寄存器
#define  MPU_GYRO_ZOUTL_REG    0X48         // 陀螺仪值,Z轴低8位寄存器


#define  MPU_USER_CTRL_REG     0X6A         // 用户控制寄存器
#define  MPU_PWR_MGMT1_REG     0X6B         // 电源管理寄存器1
#define  MPU_PWR_MGMT2_REG     0X6C         // 电源管理寄存器2


#define  MPU_INTBP_CFG_REG     0X37  // 中断/旁路设置寄存器
#define  MPU_INT_EN_REG        0X38  // 中断使能寄存器
#define  MPU_INT_STA_REG       0X3A  // 中断状态寄存器


#define  MPU_FIFO_EN_REG       0X23         // FIFO使能寄存器
#define  MPU_FIFO_CNTH_REG     0X72         // FIFO计数寄存器高八位
#define  MPU_FIFO_CNTL_REG     0X73         // FIFO计数寄存器低八位
#define  MPU_FIFO_RW_REG       0X74         // FIFO读写寄存器

void mpu6050_reset(void);
uint8_t mpu6050_init(void);
void mpu6050_set_lpf(uint16_t lpf);
void mpu6050_set_rate(uint16_t rata);
void mpu6050_set_accelerated_speed(uint8_t data);
void mpu6050_set_gyroscope(uint8_t data);

void mpu6050_read_accelerated_speed(int16_t *accelerated_speed_x,int16_t *accelerated_speed_y,int16_t *accelerated_speed_z);

void mpu6050_read_gyroscope(int16_t *gyroscope_x,int16_t *gyroscope_y,int16_t *gyroscope_z);

float mpu6050_read_temperature(void);


uint8_t mpu6050_write_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf);
uint8_t mpu6050_read_len(uint8_t addr,uint8_t reg,uint8_t len,uint8_t *buf);

使用特权

评论回复
40
发顺丰更大nc|  楼主 | 2023-12-28 16:13 | 只看该作者
添加文件delay.c
#include "main.h"
#include "delay.h"

void delay_us(uint32_t n)
{
        uint8_t j;
        while(n--)
        for(j=0;j<10;j++);
}
void delay_ms(uint32_t n)
{
        while(n--)
        delay_us(1000);
}
void get_ms(unsigned long *time)
{

}

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则