This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

【TI 测评】TI-MSP432P401R LanchPad评测 I2C采样加速度传感器计步功能及OLED显示

Other Parts Discussed in Thread: MSP432WARE

         很荣幸在21IC论坛活动中获得一块MSP432P401R LanchPad。拿到开发板后,先搭建开发环境,MSP432P401R可在CCS、KEIL、IAR 3个IDE平台都可开发,这里选择了比较熟悉的KEIL。并对MSP432P401R的SDK进行熟悉。

         刚好手头有一块带6轴LSM6DSO传感器的板子和一块0.96寸的OLED屏,两个都可通过I2C进行通讯。LSM6DSO传感器自带计步功能,既通过中断通知计步事件,也可以通过读取对应的寄存器获得。那就做一个计步功能,来测试MSP432P401R的I2C功能。

         下图是I2C的框架图

        MSP432P401R的I2C模块包括下列功能:

7位和10位设备寻址模式

启动、重启和停止

多主发射机/接收机模式

从接收机/发射机模式

支持高达100 Kbps的标准模式、高达400 Kbps的快速模式和高达1 Mbps的快速模式

主模式下可编程UCXCLK频率

专为低功耗设计

具有中断能力和自动停止断言的8位字节计数器

多达四个硬件从地址,每个都有自己的中断和DMA触发器

从机地址和地址接收中断的屏蔽寄存器

时钟低超时中断,以避免总线暂停

 

I2C模块的功能非常丰富。此次评测只使用I2C的基本功能。

硬件连接为SCL -- P1.7,SDA -- P1.6,gpio中断 -- P5.0。

 

 

 

/* DriverLib Includes */

#include <ti/devices/msp432p4xx/driverlib/driverlib.h>

 

/* Standard Includes */

#include <stdint.h>

#include <stdbool.h>

#include "i2c_driver.h"

#include "oled_i2c.h"

#include "Lsm6dso.h"

 

#define system_jump_time     1000    //   1/system_jump_time = 1ms

 

/* Slave Address for I2C Slave */

#define SLAVE_ADDRESS_1 0x48

#define SLAVE_ADDRESS_2 0x49

#define NUM_OF_REC_BYTES   10

 

#define I2C_DELAY           50

 

 

uint32_t i, j;

uint32_t pedometerCnt, pedometerCntOld = 0xffffffff;

static uint8_t index, indexOld = 0xff;

 

//一次滴答中断的tick数

uint32_t System_tick_num;

static uint32_t delayCnt = 0xffffffff, delayTarget = 0;

static uint8_t delayFinFlag = 0;

 

static volatile uint8_t Lsm6dsoEventDetected = 0;

uint8_t pedoFlag = 0;

 

//

void pedometerShow(void);

 

 

 

void MCU_Init()

{



// Set P1.0 to output direction

GPIO_setAsOutputPin(GPIO_PORT_P1, GPIO_PIN0);

 

/* Configuring P1.1 as an input and enabling interrupts */

MAP_GPIO_setAsInputPinWithPullUpResistor(GPIO_PORT_P1, GPIO_PIN1);

MAP_GPIO_clearInterruptFlag(GPIO_PORT_P1, GPIO_PIN1);

MAP_GPIO_enableInterrupt(GPIO_PORT_P1, GPIO_PIN1);

MAP_Interrupt_enableInterrupt(INT_PORT1);

 

/* Configuring P1.1 as an input and enabling interrupts */

MAP_GPIO_setAsInputPinWithPullDownResistor(GPIO_PORT_P5, GPIO_PIN0);

MAP_GPIO_clearInterruptFlag(GPIO_PORT_P5, GPIO_PIN0);

MAP_GPIO_enableInterrupt(GPIO_PORT_P5, GPIO_PIN0);

MAP_Interrupt_enableInterrupt(INT_PORT5);



/* Enabling SRAM Bank Retention */

MAP_SysCtl_enableSRAMBankRetention(SYSCTL_SRAM_BANK1);



/* Enabling MASTER interrupts */

MAP_Interrupt_enableMaster();

}

 

 

void SysTick_Init(void)

{

         /* Setup SysTick Timer for 10ms interrupts */

         System_tick_num = SystemCoreClock / system_jump_time;

         if (SysTick_Config(System_tick_num))

         {

//   OLED_ShowStr(1, 3, "SysTick err", 2);

//   OLED_ON();//OLED唤醒

                   while (1);

         }

 

}

 

 

void delayMS(uint32_t num)

{

delayTarget = num;

delayCnt = 0;

delayFinFlag = 0;

while(!delayFinFlag);

}

 

 

int main(void)

{

/* Disabling the Watchdog */

MAP_WDT_A_holdTimer();



MCU_Init();

SysTick_Init();

BSP_I2C_Init();

 

for(i = 0; i < 4; i++)

{

   // Toggle P1.0 output

   GPIO_toggleOutputOnPin(GPIO_PORT_P1, GPIO_PIN0);

 

   delayMS(250);

}



OLED_Init();





if(0 == Lsm6dso_Init())

{

   OLED_ShowStr(0, 1, "PEDOMETER :", 1);

}

else

{

   OLED_ShowStr(1, 3, "Lsm6dso err", 2);

   OLED_ON();//OLED唤醒

   while(1);

}



pedometerCnt = 0;



while(1)

{

   if(Lsm6dsoEventDetected)

   {

     Lsm6dsoEventDetected = 0;

     if(RET_OK == Get_Lsm6dso_Event(&pedoFlag))

     {

       pedoFlag = 0;

       pedometerCnt++;

     }

   }

   pedometerShow();

}

}

 

void SysTick_Handler(void)

{

if(delayCnt < delayTarget)

{

   delayCnt++;

   if(delayCnt >= delayTarget)

   {

     delayFinFlag = 1;

   }

}

}

 

 

void pedometerShow()

{

stOledShow currRow;

uint32_t pedometerCntShow;



if(pedometerCntOld == pedometerCnt)

{

   return;

}



pedometerCntOld = pedometerCnt;

pedometerCntShow = pedometerCnt;



index = 0;

currRow.str[MAX_ROW_STR_NUM] = 0x0;

while(pedometerCntShow > 9)

{

   index++;

   currRow.str[MAX_ROW_STR_NUM - index] = (pedometerCntShow % 10) + 0x30;

   pedometerCntShow /= 10;

}

index++;

if(index > MAX_PEDOMETER_INDEX)

{

   index = 1;

   currRow.str[MAX_ROW_STR_NUM - index] = 0x21;

   index++;

   currRow.str[MAX_ROW_STR_NUM - index] = 0x4c;

   index++;

   currRow.str[MAX_ROW_STR_NUM - index] = 0x6e;

   index++;

   currRow.str[MAX_ROW_STR_NUM - index] = 0x6e;

   index++;

   currRow.str[MAX_ROW_STR_NUM - index] = 0x41;

}

else

{

   currRow.str[MAX_ROW_STR_NUM - index] = (pedometerCntShow % 10) + 0x30;

}

if(indexOld != index)

{

   indexOld = index;

   currRow.x = 0;

   currRow.y = 2;

   OLED_Fill_Line(currRow.y, 0x0);

   OLED_Fill_Line(currRow.y+1, 0x0);

   OLED_Fill_Line(currRow.y+2, 0x0);

   OLED_Fill_Line(currRow.y+3, 0x0);

}

currRow.y = 3;

currRow.TextSize = 4;

currRow.x = (ROW_PIXEL - 16 * index) / 2;

OLED_ShowStr(currRow.x, currRow.y, &currRow.str[MAX_ROW_STR_NUM - index], currRow.TextSize);

}

 

/* GPIO ISR */

void PORT1_IRQHandler(void)

{

   uint32_t status;

 

   status = MAP_GPIO_getEnabledInterruptStatus(GPIO_PORT_P1);

   MAP_GPIO_clearInterruptFlag(GPIO_PORT_P1, status);

 

   /* Toggling the output on the LED */

   if(status & GPIO_PIN1)

 {

//       MAP_GPIO_toggleOutputOnPin(GPIO_PORT_P1, GPIO_PIN0);

     pedometerCnt = 0;

   }

 

}

 

/* GPIO ISR */

void PORT5_IRQHandler(void)

{

   uint32_t status;

 

   status = MAP_GPIO_getEnabledInterruptStatus(GPIO_PORT_P5);

   MAP_GPIO_clearInterruptFlag(GPIO_PORT_P5, status);

 

   /* Toggling the output on the LED */

   if(status & GPIO_PIN0)

   {

//     if(GPIO_INPUT_PIN_HIGH == GPIO_getInputPinValue(GPIO_PORT_P5, GPIO_PIN0))

     {

         Lsm6dsoEventDetected = 1;

     }

   }

}

 

 

I2C调试期间遇到了很多问题,也参考了E2E上帖子解决了问题(具体的网页一时找不到了)。这里把驱动文件上传上来,可供大家参考。

0167.i2c_driver.c
Fullscreen
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
//*****************************************************************************
//
// Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
//
// Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//
// Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the
// distribution.
//
// Neither the name of Texas Instruments Incorporated nor the names of
// its contributors may be used to endorse or promote products derived
// from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
//****************************************************************************
//************************MODIFICATON INFORMATION*****************************
//Modified from original source located at:
// https://e2e.ti.com/support/microcontrollers/msp430/f/166/p/472504/1701554#1701554
//
//Modifed by Reid Kersey, CEO, Sniffer GPS - 7/19/2017
// sniffergps.com
// reid@sniffergps.com
// 678-209-2215
//
//Updates:
//6/7/2017
//Changed EUSCI_Bx_MODULE to EUSCI_Bx_BASE
//Changed from using B1 to allowing use of any Bx Module
//Added funciton description comments
//7/19/2017
//removed slow speed bug on B2 and B3
//Feel free to contact me about modifications to this code or questions about usage,
//however I am not the original author. Credit goes to DavidL https://e2e.ti.com/members/2005340
#include "msp432.h"
#include "i2c_driver.h"
//#include "driverlib.h"
#include <ti/devices/msp432p4xx/driverlib/driverlib.h>
//*****************************************************************************
//
// Definitions
//
//*****************************************************************************
//*****************************************************************************
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

7875.i2c_driver.h

 

  • 多谢分享,干的漂亮。
  • 432有三套库函数:MSP432ware的,Keil版本的,还有simplelink版本的。
  • 谢谢分享!
  • Keil库版本有的好象simplelink版本都有。MSP432ware版本下载需要审核,下不了-_-!
  • 请问下载不了,有什么提示吗?

    您是如何选择的呢?
  • 代码实现比较清楚,最后也给了I2C的驱动,对于其他小伙伴用I2C驱动OLED或其他器件很方便。有干货,如果能再详细点就好了,将实现这个评测过程中遇到的问题和解决方法描述下,对于小伙伴少踩坑就更有帮助了。
  • 这位同学直接贴上代码,show you the code,先赞一下。对重点用到的I2C接口的定义、原理说的比较清楚,最后给了I2C的驱动,对需要使用I2C的朋友是个帮助。感觉差点就是没有图文并茂,如果能把过程说的再多一点就好了。
  • 很详细的一篇评测文章,代码比较多,最后也给了I2C的驱动文件,能给大家带来实际的帮助。
    使用OLED显示验证了I2C器件的数据通信结果。投一票。
  • 这篇分享结合了作者的其他模块,OLED屏和LSM6DSO传感器,主要使用I2C功能,代码也比较清晰,如果加上一些注释会更好,方便参考移植。但是呢,开发期间遇到了哪些问题,是怎样解决的并没有详细说明,我觉得这方面的可以详细点讲,避免其他人踩坑,加入了空闲的模块结合开发板实现各种功能是很好的试用,感谢分享!
  • 之前页面显示需要审核,没有下载按钮。我今天又试了一下,可以下载了。

  • 很高兴您能解决问题!
  • 分享的评测不错,结合实际应用。通过传感器和OLED的使用学习了I2C总线外设使用方法。虽然遇到了困难,但最终都能解决,完成实际功能很不错。要是再把一些评测过程中遇到的问题和解决方法提出来就更好,方便帮助其他人。
  • 思路不错,但是没有把过程中碰到什么问题,如何解决的写出来就略显文章差一点了,对初学网友解决问题帮助就差了点。

  • 楼主评测的内容丰富,提供了驱动文件,可以相互学习交流,充分展示了LSM6DSO传感器自带计步功能,不错。
  • 完整的实现了IC测量功能,代码很规范,多谢分享
  • (1)通过I2C把LSM6DSO、OLED屏联系起来,MSP432P401R进行信号处理和通讯。项目逻辑正确。
    (2)技术成熟,项目有应用前景。
    (3)多个硬件连接略显凌乱,影响计步测量准确度。
    (4)I2C调试方法和问题可总结出来,供大家参考。
  •   这篇分享结合使用了作者自己 传感器+显示模块,主要使用I2C功能驱动,具体也给了驱动代码,代码调理也比较清晰,并结合了资料分析,这个很值得初学的小伙伴参考;

      缺点就是代码少了些注释,需要有一定代码功底的人才能看懂,还有就是如果有调试过程的还有出现的问题及解决过程总结等的分享就更好了。

      虽如此但还是作者感谢分享!

  • 只能说,代码清晰,图例也不错,已经超过了入门水平,针对实验还是很有心得,实验中显示的结果也令人满意,如果多点变化,也许会更好,针对入门者来说,不是资料多基础多,也不是实验如何好,而是入门步骤让人通俗易懂,这样学习的人才会发现入门不难,从而有了信心,一般来说,一个实验测评帖子,都需要入门者,先得有一定的基础,所以在测评板子之前,可以先列出所需知识包括资料名,书籍名,然后是开箱,可以显示一些资料或者视频教学的链接,然后再针对板子进行实验目的的解说,详细的实验步骤,最终完成的详细图片和文字说明,最后可以有一些引导,这样对于初学者入门者来说,就更加简便了,看了很多的测评,发现很多人的深层次的文章,是新人看不懂,技术人员看着简单,没有很好的定位,本文还是标识了代码,和实验的图片,所以点个赞,支持下。
  • 这个就有点搞笑了,TI的开发板,而传感器确用了ST的。哈哈!说明作者功底挺深。

x 出现错误。请重试或与管理员联系。