一般情况下,beaglebone black默认启动两个cape: 
1、BB-BONE-EMMC-2G 
2、BB-BONELT-HDMI

我们可以通过编辑uEnv.txt的文件来决定是否启动HDMI,步骤如下 
1、加载启动分区:
    mkdir /mnt/sdcard
    mount /dev/mmcblk0p1  /mnt/card
2、编辑uEnv.txt
    vim /mnt/card/uEnv.txt

文件内容如下
    ##These are needed to be compliant with Angstrom's 2013.06.20 u-boot.
    loadaddr=0x82000000
    fdtaddr=0x88000000
    rdaddr=0x88080000

initrd_high=0xffffffff
    fdt_high=0xffffffff

##These are needed to be compliant with Debian 2014-05-14 u-boot.

loadximage=load mmc 0:2 ${loadaddr} /boot/vmlinuz-${uname_r}
    loadxfdt=load mmc 0:2 ${fdtaddr} /boot/dtbs/${uname_r}/${fdtfile}
    loadxrd=load mmc 0:2 ${rdaddr} /boot/initrd.img-${uname_r}; setenv rdsize ${filesize}
    loaduEnvtxt=load mmc 0:2 ${loadaddr} /boot/uEnv.txt ; env import -t ${loadaddr} ${filesize};
    check_dtb=if test -n ${dtb}; then setenv fdtfile ${dtb};fi;
    loadall=run loaduEnvtxt; run check_dtb; run loadximage; run loadxrd; run loadxfdt;

mmcargs=setenv bootargs console=tty0 console=${console} ${optargs} ${cape_disable} ${cape_enable} root=/dev/
    mmcblk0p2 rootfstype=${mmcrootfstype} ${cmdline}

uenvcmd=run loadall; run mmcargs; bootz ${loadaddr} ${rdaddr}:${rdsize} ${fdtaddr};

在”mmcargs=setenv…”一行插入以下语句
    optargs=quiet capemgr.disable_partno=BB-BONELT-HDMI,BB-BONELT-HDMIN
保存,退出

3、重启

4、开机查看slots已经变成了这样:

root@beaglebone:~# cat $SLOTS 
 0: 54:PF--- 
 1: 55:PF--- 
 2: 56:PF--- 
 3: 57:PF--- 
 4: ff:P-O-L Bone-LT-eMMC-2G,00A0,Texas Instrument,BB-BONE-EMMC-2G
 5: ff:P-O-- Bone-Black-HDMI,00A0,Texas Instrument,BB-BONELT-HDMI
 6: ff:P-O-- Bone-Black-HDMIN,00A0,Texas Instrument,BB-BONELT-HDMIN

eQEP 全称Enhanced Quadrature Encoder Pulse 增强型正交编码脉冲,也具有输入的特性,设置GPIO引脚模式为eQEP1A_in或eQEP1B_in,A和B是正交编码的信号输入,或者是脉冲(A)和方向(B)的信号输入。
I是Index,也就是零位信号输入,S是Strobe,也就是锁存信号。

EQEP功能模块的输入涉及4个GPIO
AM335X的PWMSS分三个部分:
Enhanced PWM Module(ePWM);
Enhanced Capture Module(eCAP);
Enhanced Quadrature Encoder Pulse Module(eQEP).

先加载PWM功能的设备树 echo am33xx_pwm > /sys/devices/bone_capemgr.9/slots
    echo bone_eqep1 > /sys/devices/bone_capemgr.9/slots

然后加载eqep:beaglebone上sysfs条目的路径是
/sys/devices/ocp.*/{epwmss_addr}.epwmss/{eqep_addr}.eqep/
对于eqep 0,epwmss地址为48300000,eqep地址为48300180。
对于eqep 1,epwmss地址为48302000,eqep地址为48302180。
对于eqep 2,epwmss地址为48304000,eqep地址为48304180。

需要注意的是,Beaglebone上只有eQEP 1和eQEP 2可用,而Beaglebone Black上提供了所有这三个版本。这是因为在原始Beaglebone上,没有为eQEP0断开编码器时钟输入引脚之一。
如果使用eQEP 1和/或2,则必须在Beaglebone和Beaglebone Black上禁用HDMI,因为它们与LCD_数据线共享引脚。

1、测试的编码器为ROTARY增量式编码器,共4根线(vcc、GND、A相、B相);
2、选择P8_35 EQEP1A 和P8_33 EQEP1B引脚,分别作为A、B相,VCC接P9_08的sys_5v,GND接P9_02的GND;(P8_41 P8_42为EQEP2A 和P8_33 EQEP2B引脚)
3、编写程序读取position的数据即可

#include <stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h> #define ENCODERDATA1 "/sys/devices/ocp.3/48302000.epwmss/48302180.eqep/"
#define ENCODERDATA2 "/sys/devices/ocp.3/48304000.epwmss/48304180.eqep/"
#define MAX_LINE 100
struct encoderdata{
char encoder1[MAX_LINE];
char encoder2[MAX_LINE];
char encoder3[MAX_LINE];
}; main(int argc, char **argv)
{
struct encoderdata p1;
FILE *stream = NULL;
FILE *stream1 = NULL;
FILE *stream2 = NULL;
while(1)
{
stream = fopen(ENCODERDATA"position","r+");
if(!stream){
printf("file error \n");
return ;}
stream1 = fopen(ENCODERDATA1"position","r+");
if(!stream1){
printf("file error1 \n");
return ;}
stream2 = fopen(ENCODERDATA2"position","r+");
if(!stream2){
printf("file error2 \n");
return ;} fgets(p1.encoder1, MAX_LINE, stream);
fgets(p1.encoder2, MAX_LINE, stream1);
fgets(p1.encoder3, MAX_LINE, stream2); fclose(stream);
fclose(stream1);
fclose(stream2);
usleep(100000); printf("\nThe current encoder data is: %s, %s, %s\n",p1.encoder1,p1.encoder2,p1.encoder3);
}
}

  

Beaglenone读取编码器数据的更多相关文章

  1. 读取编码器信息Python2.7和Python3.3版本差异及解决,一次订阅多次调用callback的解决

    1. Python3.3以字节类型返回编码器信息,b'...',BUF: b'\xc3KOO\x00OO\x00OO\x00OO\x00OO\x00\x03\x00\x00\x00\x00\x99R\ ...

  2. java的poi技术读取Excel数据到MySQL

    这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...

  3. Hive读取外表数据时跳过文件行首和行尾

    作者:Syn良子 出处:http://www.cnblogs.com/cssdongl 转载请注明出处 有时候用hive读取外表数据时,比如csv这种类型的,需要跳过行首或者行尾一些和数据无关的或者自 ...

  4. 读取数据库数据,并将数据整合成3D饼图在jsp中显示

    首先我将生成饼图的方法独立写成一个PieChar.java类,详细代码如下:(数据库需要自己建,如有需要的话) import java.io.IOException; import java.sql. ...

  5. .NET读取Excel数据,提示错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序

    解决.NET读取Excel数据时,提示错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序的操作: 1. 检查本机是否安装Office Access,如果未安装去去h ...

  6. oledbdataadapter 读取excel数据时,有的单元格内容不能读出

    表现:excel中某列中,有的单元格左上角有绿色箭头标志,有的没有,c#编写读取程序,但是只能读取出带绿色箭头的单元格中的内容,其余不带的读取不到内容 原因:excel中单元格因为是文本格式而存储了数 ...

  7. wcf序列化大对象时报错:读取 XML 数据时,超出最大

    错误为: 访问服务异常:格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出 错: request.InnerException 消息是“反序 ...

  8. Openxml入门---Openxm读取Excel数据

    Openxml读取Excel数据: 有些问题,如果当Cell 里面是 日期和浮点型的话,对应的Cell.DataType==Null,对应的时间会转换为一个浮点型,对于这块可以通过DateTime.F ...

  9. NPOI操作excel之读取excel数据

    NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目.  一.下载引用 去NPOI官网http://npoi.codeplex. ...

随机推荐

  1. Oracle递归查询,Oracle START WITH……CONNECT BY查询

    Oracle递归查询,Oracle START WITH……CONNECT BY查询,Oracle树查询 ================================ ©Copyright 蕃薯耀 ...

  2. spring boot中的jave注解学习

    在spring中,不仅框架作者会使用java注解,开发者也常使用. 可以随手给个例子:在org.springframework.boot.autoconfigure.jdbc.DataSourcePr ...

  3. lis最长上升子序列

    因为是最长上升的,可以用一个数组储存上升的序列,如果后一个数字比数组的最大数字还大,就加到末尾去,如果不大于,那么就可以把这个数组中比他大的数字替换掉,因为如果数字更小,后面上升序列更长的可能性更大, ...

  4. dedecms (织梦)漏洞&exp整理

    [通杀]dedecms plussearch.php 注入漏洞利用方式看结果如果提示Safe Alert: Request Error step 2 !那么直接用下面的exp查看源代码打印帮助1 /p ...

  5. Java设计模式系列 — 构造器模式

    想象下你有一个类,像下图所示有许多属性.假设你想让你的类不可变(顺便说一下,除非有一个好的理由不这样做,否则你应该坚持.但是我们会以另一种方式来达到要求.) public class User { p ...

  6. swust oj 1075

    求最小生成树(Prim算法) 1000(ms) 10000(kb) 2251 / 4487 Tags: 生成树 求出给定无向带权图的最小生成树.图的定点为字符型,权值为不超过100 的整形.在提示中已 ...

  7. c++试题2

    一.写出下列程序的运行结果(40 分) 1.for(i=1;i<5;i++); cout << “OK” << endl; 程序执行后的输出结果是:  OK    ___ ...

  8. OGC相关概念解析

    网络覆盖服务 (WCS) 网络要素服务 (WFS) 网络地图服务 (WMS) 网络地图切片服务 (WMTS) 网络处理服务 (WPS) 1.Web 地图服务(WMS)能够根据用户的请求返回相应的地图( ...

  9. [ERROR] - Error reading string. Unexpected token: StartObject. Path 'formData', line 1, position 13.

    公司流程框架: businessData 为 string 所有要使用JSON.stringify();

  10. sqlserver开启远程访问

    1.通过本地连接数据库,选择数据库——右键——属性 2.在连接选项勾选“允许远程连接到此服务器” 3.打开sqlserver配置管理器 4.到sqlserver网络配置——XXX的协议——TCP/IP ...