DE10-Lite加速度计使用教程

1. 概述

DE10-Lite实验板上有一片5轴加速度计芯片ADXL345(通常称为G-sensor)。它可以用来测量板子的倾斜角度。本文讲述如何以50次/秒的速度读取其X轴和Y轴的数据。

在使用SystemBuilder建立工程时,勾选Accelerometer项。

这个接口有一点复杂,下面的*.zip文件里提供了代码和说明文件。

把以下文件复制到你的工程的hdl/子目录:

hdl/accel.v

 
  
hdl/spi_control.v

 
  
hdl/spi_serdes.v

   压缩包里的test/子目录下是测试文件,可以借鉴。

2.模块说明

下面讲述如何使用spi_control模块。

  1. spi_control.v

这是一个用来控制主从(FPGA和加速度计)通信的模块。这个模块初始化DE10-Lite上的加速度计并周期性的采样其X轴和Y轴的数据。使用这个模块之前,请仔细阅读下面的参数和端口汇总信息。注意模块的3个时钟信号的特殊要求。生成这3个时钟信号的详细描述见文尾。

参数

n  SPI_CLK_FREQ—用于SPI从端通信的时钟频率。这个时钟频率也是spi_control和spi_serdes里的大部分逻辑使用的时钟信号。这个只在2MHz验证过,所以,除非必要,不要修改这个值。

n  UPDATE_FREQ—从G-sensor采样的频率,这个只在50Hz验证过,非必要,勿修改。

端口

n  reset_n  为0时,复位位。

n  clk  模块的时钟信号。在模块例化中,确保data_update保持一个时钟周期的高电平。这个信号经过25MHz和50MHz测试。

n  spi_clk  驱动SPI的内部逻辑时钟信号。注意:这个信号必须与clk同相,否则,时序约束条件可能就不满足。

n  spi_clk_out  驱动SPI外部逻辑的时钟信号。注意:其频率必须与spi_clk相同,但相位偏前270度。

n  data_update  控制信号。当获取有效的data_x和data_y的新值时,保持一个时钟周期的高电平。

n  data_x  G_sensor的X轴的数值(当七段数码管正对着你时,左右翻转实验板),有符号的16位2的补码。只有当data_update==1时,它才有效。

n  data_y  G_sensor的Y轴的数值(当七段数码管正对着你时,前后翻转实验板),有符号的16位2的补码。只有当data_update==1时,它才有效。

n  SPI_CSN  SPI协议的片选信号。直接连接到顶层模块中同名端口。

n  SPI_CLK  SPI协议的时钟信号。直接连接到顶层模块中同名端口。

n  SPI_SDI  SPI主到从的数据线。直接连接到顶层模块中同名端口。

n  SPI_SDO  SPI从到主的数据线。直接连接到顶层模块中同名端口。

2.spi_serdec.v

这个模块包含一个串并转换器,用于FPGA和加速度计之间的4线模式的SPI通信。在设计中使用spi_control.v模块会例化这个模块。这个模块主要用来主从交互,不支持突发访问。

3.用锁相环配置时钟

前面提到的三个时钟信号:clk,spi_clk,spi_clk_out可以用一个PLL模块生成。参考之前的PLL例化教程。

在参数设置时,c0,c1,c2的值如下:

* c0 - Freq: 25
MHz, Phase: 0

* c1 - Freq: 2
MHz, Phase: 0

* c2 - Freq: 2
MHz, Phase 270

你设计的模块时钟信号是c0。

把这些时钟信号连接到spi_control模块的输入端口:

* c0 → clk

* c1 → spi_clk

* c2 →
spi_clk_out

4.输出的范围

虽然加速度计的输出是16位的2的补码,大概在[-260,+260],但观测在[-500,+500].

5.输出的时序

实际上,新的加速度计的值随时都会产生,但是需要跟主时钟同步(25MHz或50MHz)。因此,在某些时候需要新的加速度计输出值的应用程序将需要缓冲加速度计的输出。最简单的缓冲器是一个16位寄存器,当加速计的输出有效时写入,并且可以在任何时候读取。

References:

1. EEC180 Tutorial: Using the accelerometer on the DE10-LITE board

https://www.ece.ucdavis.edu/~bbaas/180/tutorials/accelerometer.html

Written by YongfengXie

2022/05/31   Written

DE10-Lite加速度计使用教程的更多相关文章

  1. 刻录DVD.XP系统盘(U盘)

    ZC:用这个软件,安装太慢了... 忽然发现 以前有别的软件可以使用:http://www.cnblogs.com/vmskill/p/6196522.html 1.我是在这个论坛看到 这个工具的:h ...

  2. 免费申请使用IBM Cloud Lite(轻量套餐) 详细教程指南

    注册轻量帐户可在 IBM CLOUD控制台中使用所选的显示有轻量标记的免费轻量套餐来构建应用程序和探索服务.轻量帐户不会到期,也无需信用卡. 本文详细的介绍了一下,免费云服务的申请以及使用!这次使用I ...

  3. Jetty使用教程(一)——开始使用Jetty

    一.Jetty简介 1.1 什么是Jetty Jetty是一个提供HHTP服务器.HTTP客户端和javax.servlet容器的开源项目.   这个入门教程分为五个部分: 第一部分部分重点介绍如何使 ...

  4. 【特别推荐】Web 开发人员必备的经典 HTML5 教程

    对于我来说,Web 前端开发是最酷的职业之一,因为你可以用新的技术发挥,创造出一些惊人的东西.唯一的问题是,你需要跟上这个领域的发展脚步,因此,你必须不断的学习,不断的前进.本文将分享能够帮助您快速掌 ...

  5. [分享] 从定制Win7母盘到封装详细教程 By BILL ( 10月23日补充说明 )

    [分享] 从定制Win7母盘到封装详细教程 By BILL ( 10月23日补充说明 ) billcheung 发表于 2011-10-23 00:07:49 https://www.itsk.com ...

  6. [原创] RT7 Lite win7旗舰版精简方案

    [原创] RT7 Lite win7旗舰版精简方案 墨雪SEED 发表于 2016-1-26 21:23:54  https://www.itsk.com/thread-362912-1-5.html ...

  7. 基于Nodejs生态圈的TypeScript+React开发入门教程

    基于Nodejs生态圈的TypeScript+React开发入门教程   概述 本教程旨在为基于Nodejs npm生态圈的前端程序开发提供入门讲解. Nodejs是什么 Nodejs是一个高性能Ja ...

  8. Arduino可穿戴开发入门教程(大学霸内部资料)

    Arduino可穿戴开发入门教程(大学霸内部资料) 试读下载地址:链接:http://pan.baidu.com/s/1mg9To28 密码:z5v8 介绍:Arduino可穿戴开发入门教程(大学霸内 ...

  9. Cocos2d-JS加速度计与加速度事件

    在很多移动设备的游戏使用到了加速度计,Cocos2d-JS引擎提供了访问加速度计传感器的能力.本节我们首先介绍一下加速度计传感器,然后再介绍如何在Cocos2d-JS中访问加速度计.加速度计加速度计是 ...

  10. QML官方系列教程——QML Applications

    附网址:http://qt-project.org/doc/qt-5/qmlapplications.html 假设你对Qt的官方demo感兴趣,能够參考本博客的另一个系列Qt5官方demo解析集 每 ...

随机推荐

  1. KingbaseES 扩展插件src_restrict 介绍

    插件简介 src_restrict是KingbaseES的一个扩展插件,主要用于支持来源限制功能,该功能通过黑白名单来实现.插件src_restrict默认已经加载. 查看插件是否加载 show sh ...

  2. KingbaseES V8R6运维案例之---pg_statistic toast表故障修复

    ​ 案例说明: 数据库在日常的维护过程中,执行表结构查询语句(\d t1),如下图所示,出现"missing chunk number 0 for toast value 16259 in ...

  3. 安装arch时用wpa_supplicant连接隐藏WPA2 wifi

    参考 https://bbs.archlinux.org/viewtopic.php?id=156074 1.终端输入 vim /etc/wpa_supplicant/wpa_supplicant.c ...

  4. Makefile 简单学习

    一.Makefile 简介 Makefile 是一种常用于编译的脚本语言.它可以更好更方便的管理你的项目的代码编译,节约编译时间(没改动的文件不编译).注意 Makefile 文件命令必须是 Make ...

  5. Windows下mDNS查询API—DnsStartMulticastQuery/DnsStopMulticastQuery的使用

    背景及问题: 目前很多局域网设备通过mNDS协议实现互联,IP地址为自动IP段-169.254.x.x,有时候设备厂家提供的API需要通过知晓局域网中的IP地址/设备名,才能连接该设备.这样要求每个软 ...

  6. #期望,树的直径#51nod 1803 森林直径

    题目 有一棵 \(n\) 个结点的树,按顺序给出树边 \((fa[i],i)\), \(Q\) 次询问查询如果只选取第 \([l,r]\) 条树边,问森林的直径 \(fa[i]\) 的生成方式为 \( ...

  7. 组合数学——Min-Max容斥

    Min-Max 容斥,即 $$\max(S)=\sum_{T\in S,T\neq\emptyset}(-1)^{|T|-1}\min(T)$$ 接下来证明上面那个式子是对的.定义 \(S\) 中共有 ...

  8. C++ 开发者必读经典书籍推荐

    如果你正在学习C++,那么一本好的教材或参考书可以事半功倍.以下是几本我个人推荐的C++书籍或视频 C++基础 看书 C++ Primer C++程序设计语言 Effective C++ More E ...

  9. HMS Core分析服务智能运营6.5.1版本上线

    HMS Core分析服务智能运营6.5.1版本上线,三大"更"新,助力开发者提升运营体验. 1.活动效果更前置:支持受众预估,提前判断活动效果: 2.活动流程更规范:新增活动审核功 ...

  10. CDH5.15.1集群安装部署

    CDH集群安装部署 大数据平台软件清单 本文部署的大数据基础平台为CDH,操作系统的版本为CentOS6.8,JDK的版本为1.8,Cloudera Manager与CDH的版本为5.15.1,数据库 ...