arm linux串口蓝牙工具移植及使用【转】

本文转载自:http://blog.csdn.net/hclydao/article/details/51451725

p6212中串口蓝牙在linux下的使用记录

一、linux蓝牙工具移植

主要使用到的工具及相关库如下:

bluez-libs-3.36

libxml2-2.7.4

dbus-1.0.2

glib-2.24.2

bluez-utils-3.36

openobex-1.5

下载相应的源码解压,按照上面的顺序进行编译.

bluez-libs-3.36中增加mk.sh内容如下

  1. #!/bin/sh
  2. ./configure --prefix=/usr/bluez --host=arm-linux --target=arm-linux CC=arm-cortex_a9-linux-gnueabi-gcc
  3. make
  4. make install

修改mk.sh权限直接运行,完成编译与安装,下同

libxml2-2.7.4中增加mk.sh内容如下

  1. #!/bin/sh
  2. ./configure --prefix=/usr/bluez --host=arm-linux --target=arm-linux CC=arm-cortex_a9-linux-gnueabi-gcc
  3. make
  4. make install

dbus-1.0.2中增加mk.sh内容如下

  1. #!/bin/sh
  2. echo ac_cv_have_abstract_sockets=yes>arm-linux.cache
  3. ./configure --prefix=/usr/bluez --host=arm-linux --target=arm-linux CC="arm-cortex_a9-linux-gnueabi-gcc -I/usr/bluez/include -L/usr/bluez/lib" --cache-file=arm-linux.cache --with-x=no
  4. make
  5. make install

glib-2.24.2中增加mk.sh内容如下

  1. #!/bin/sh
  2. echo ac_cv_type_long_long=yes>arm-linux.cache
  3. echo glib_cv_stack_grows=no>>arm-linux.cache
  4. echo glib_cv_uscore=no>>arm-linux.cache
  5. echo ac_cv_func_posix_getpwuid_r=yes>>arm-linux.cache
  6. echo ac_cv_func_posix_getgrgid_r=yes>>arm-linux.cache
  7. #echo gt_cv_have_gettext=no>>arm-linux.cache
  8. export NM=nm
  9. ./configure --prefix=/usr/bluez --host=arm-linux --target=arm-linux CC="arm-cortex_a9-linux-gnueabi-gcc -I/usr/bluez/include -L/usr/bluez/lib" --cache-file=arm-linux.cache
  10. make
  11. make install

bluez-utils-3.36中增加mk.sh内容如下

  1. #!/bin/sh
  2. ./configure --prefix=/usr/bluez --host=arm-linux --target=arm-linux CC="arm-cortex_a9-linux-gnueabi-gcc -I/usr/bluez/include -L/usr/bluez/lib" --enable-test
  3. make
  4. make install

openobex-1.5中增加mk.sh内容如下

  1. #!/bin/sh
  2. ./configure --prefix=/usr/bluez --host=arm-linux --enable-apps --enable-bluetooth CFLAGS=-I/usr/bluez/include LDFLAGS=-L/usr/bluez/lib CC=arm-cortex_a9-linux-gnueabi-gcc
  3. make
  4. make install

同时需要修改configure文件11311行将

  1. #  { (exit 1); exit 1; }; }
  2. { (echo 1); echo 1; }; }

将上面的exit 1这一行注释增加下面echo 1这行,忽悠掉这个错误

所有文件都会安装在/usr/bluez目录下。拷贝/usr/bluez目录下所有文件到目标板/usr目录下

对于我使用的这个模块wifi和bt是一起的,在android下能正常使用,在linux下bt要正常识别还需要另一个工具brcm_patchram_plus最后我会给下载地址,同时还需要固件文件bcm43438a0.hcd这个可以直接从android文件系统下拷贝过来.

二、使用说明
加载完ap6212模块驱动后,因为这个有电源控制,所以首先要给bt上电,执行rfkill list查看bt对应的控制节点,如下图

arm linux串口蓝牙工具移植及使用【转】

可以看到bt对应的是0节点

在/usr/sbin下新建一个脚本命名为btstart内容如下:

  1. #!/bin/sh
  2. echo 1 > /sys/class/rfkill/rfkill0/state
  3. brcm_patchram_plus --patchram /etc/firmware/bcm43438a0.hcd --baudrate 3000000 --enable_lpm --enable_hci --no2bytes /dev/ttyAMA1 &

echo 1 >xxxx是给bt上电

后面这个是加载固件,这里我的bt接的是串口1对应的串口设备节点是/dev/ttyAMA1,波特率设置为3M

保存这个脚本,修改权限后执行

arm linux串口蓝牙工具移植及使用【转】

等待几秒会出现Done setting line discpline说明设置已经完成,此时就可以查看到bt设备了,执行hciconfig -a

arm linux串口蓝牙工具移植及使用【转】

正常识别到后,接着就来看怎么使用.

首先需要开启dbus守护进程,hcid需要这个

前面已经将安装到的/usr/bluez下的文件全部拷贝到了目标板的/usr目录下,此时在目标板会有/usr/etc/dbus-1/system.conf文件

修改system.conf文件第18行

  1. <!-- Run as special user -->
  2. <user>messagebus</user>

将messagebus改为root或者已经存在的用户名.

然后修改/usrc/etc/bluetooth/hcid.conf

  1. #
  2. # HCI daemon configuration file.
  3. #
  4. # HCId options
  5. options {
  6. # Automatically initialize new devices
  7. autoinit yes;
  8. # Security Manager mode
  9. #   none - Security manager disabled
  10. #   auto - Use local PIN for incoming connections
  11. #   user - Always ask user for a PIN
  12. #
  13. security user;
  14. # Pairing mode
  15. #   none  - Pairing disabled
  16. #   multi - Allow pairing with already paired devices
  17. #   once  - Pair once and deny successive attempts
  18. pairing multi;
  19. # Default PIN code for incoming connections
  20. passkey "BlueZ";
  21. }
  22. # Default settings for HCI devices
  23. device {
  24. # Local device name
  25. #   %d - device id
  26. #   %h - host name
  27. name "BlueZ (%d)";
  28. # Local device class
  29. class 0x000100;
  30. # Default packet type
  31. #pkt_type DH1,DM1,HV1;
  32. # Inquiry and Page scan
  33. iscan enable; pscan enable;
  34. # Default link mode
  35. #   none   - no specific policy
  36. #   accept - always accept incoming connections
  37. #   master - become master on incoming connections,
  38. #            deny role switch on outgoing connections
  39. lm accept;
  40. # Default link policy
  41. #   none    - no specific policy
  42. #   rswitch - allow role switch
  43. #   hold    - allow hold mode
  44. #   sniff   - allow sniff mode
  45. #   park    - allow park mode
  46. lp rswitch,hold,sniff,park;
  47. }

将security后的user改为auto 将passkey后的"BlueZ"改为"0000"改成简单点的

其中name "BlueZ (%d)";后的"BlueZ (%d)"将会成为其它设备识别到本设备时的bt的名字

passkey为其它设备主动发起配对时需要的密码,security设置为auto后,其它设备输入密码正常,就会自动与本设备进行配对,并显示配对成功.如果本设备主动发起配对,此时密码就不是这里设置的这个密码了.

修改完成后,还需要做一些链接,新建btup脚本,内容如下

  1. #!/bin/sh
  2. hciconfig hci0 up
  3. hciconfig hci0 iscan
  4. if [ ! -d /usr/bluez/etc/dbus-1 ]; then
  5. if [ ! -d /usr/bluez/etc ]; then
  6. mkdir -p /usr/bluez/etc
  7. fi
  8. ln -s /usr/etc/dbus-1 /usr/bluez/etc/dbus-1
  9. fi
  10. #for dbus
  11. if [ ! -d /usr/bluez/var/run/dbus ]; then
  12. if [ ! -d /var/run/dbus ]; then
  13. mkdir -p /var/run/dbus
  14. fi
  15. if [ ! -d /usr/bluez/var/run ]; then
  16. mkdir -p /usr/bluez/var/run
  17. fi
  18. ln -s /var/run/dbus /usr/bluez/var/run/dbus
  19. fi
  20. if [ ! -d /usr/bluez/lib/bluetooth/plugins ]; then
  21. if [ ! -d /usr/bluez/lib/bluetooth ]; then
  22. mkdir -p /usr/bluez/lib/bluetooth
  23. fi
  24. ln -s /usr/lib/bluetooth/plugins /usr/bluez/lib/bluetooth/plugins
  25. fi
  26. dbus-daemon --system
  27. hcid -f /usr/etc/bluetooth/hcid.conf -n -d &

上面的这些链接的创建是为了下面这两条命令能正常执行,也可以先不创建先一条一条命令执行后面会报错,然后根据错误来创建链接.

最后一条命令

hcid -f /usr/etc/bluetooth/hcid.conf -n -d &

中的-n -d可以去掉,这里方便调试我才加上

执行btup脚本,此时会有很多打印信息输出如下图:

arm linux串口蓝牙工具移植及使用【转】

此时打开手机蓝牙进行扫描,就可以看到我们的设备了,如下图

arm linux串口蓝牙工具移植及使用【转】

点击我们的设备进行配对,输入前面我们设置好的密码0000就可以配对成功,如下图:

arm linux串口蓝牙工具移植及使用【转】

此时我们在本设备端进行扫描如下图:

arm linux串口蓝牙工具移植及使用【转】

以下把我移植的设备称为我的设备,其它带蓝牙的设备称为其它设备

我们需要通过其它设备的OBEX Object Push信道才能正常向其它设备发送文件

我们通过sdptool查看其它设备的具体信息如下图是查看的123(68:DF:DD:49:87:AF)设备的具体信息:

arm linux串口蓝牙工具移植及使用【转】

或者可以使用sdptool search OPUSH查找周围设备的具有OPUSH功能的设备

arm linux串口蓝牙工具移植及使用【转】

可以看到设备123(68:DF:DD:49:87:AF)中OBEX Object Push功能所在通道是4

此时我们可以通过这个通道给123设备发送文件,执行如下命令

arm linux串口蓝牙工具移植及使用【转】

接着输入c进行连接

arm linux串口蓝牙工具移植及使用【转】

这里会超时,不用管,然后输入p 1.png 1.png

这里p后面第一个参数1.png是我的设备上已经存在的在根目录下的1.png文件后面的1.png是以什么名字发送给其它设备,输入后回车,123设备上就会有相关提示

arm linux串口蓝牙工具移植及使用【转】

选择接收后,我的设备会输出很多信息,如下图

arm linux串口蓝牙工具移植及使用【转】

传送完成后,就可以在123设备上查看文件内容了

上面是发送,接下来是接收, 输入q退出刚才的obex_test命令

执行sdptool brower local查看我的设备bt下的OBEX Object Push所对应的通道

arm linux串口蓝牙工具移植及使用【转】

默认情况是没有这个功能的,增加这OPUSH功能

arm linux串口蓝牙工具移植及使用【转】

在执行sdptool brower local查看,此时就会出现这个功能

arm linux串口蓝牙工具移植及使用【转】

对应的是通道9

通过查看local可以看到对应的地址是FF:FF:FF:00:00:00

这里我们执行如下

arm linux串口蓝牙工具移植及使用【转】

然后输入s,输入s后,马上在123设备端,通过bt给我的设备发送文件

如果能正常接收调试信息输出如下:

arm linux串口蓝牙工具移植及使用【转】

接收完成后会保存在根目录下.

============================================
作者:hclydao
http://blog.csdn.net/hclydao
版权没有,但是转载请保留此段声明

============================================

上一篇:Android 串口蓝牙通信开发Java版本


下一篇:安卓中不同APP之间的消息通信