Chinaunix首页 | 论坛 | 博客
  • 博客访问: 108989
  • 博文数量: 13
  • 博客积分: 489
  • 博客等级: 一等列兵
  • 技术积分: 175
  • 用 户 组: 普通用户
  • 注册时间: 2011-02-12 10:06
文章分类

全部博文(13)

文章存档

2011年(13)

分类: LINUX

2011-02-17 09:56:41

TI平台使用SIRF GPS
2.Android HAL的实现
(1)制作libgps.so库
google提供的方法
 
Android.mk:
LOCAL_SRC_FILES:= main.c    //指定库的源码
LOCAL_MODULE := libgps    //指定库的名称
include $(BUILD_SHARED_LIBRARY)    //指定编译成.so库
 
(2)修改BoardConfig.mk
添加BOARD_GPS_LIBRARIES := libgps
 
由于hardware/libhardware_legacy/gps/Android.mk中指定LOCAL_SHARED_LIBRARIES
ifneq ($(BOARD_GPS_LIBRARIES),)
  LOCAL_CFLAGS           += -DHAVE_GPS_HARDWARE
  LOCAL_SHARED_LIBRARIES += $(BOARD_GPS_LIBRARIES)
endif
 
(3)修改hardware/libhardware_legacy/gps/gps.cpp
  1. static void
  2. gps_find_hardware( void )
  3. {
  4.     sGpsInterface = gps_get_hardware_interface();
  5.     if (!sGpsInterface)
  6.         LOGD("no GPS hardware on this device\n");
  7. }
gps_get_hardware_interface()在libgps.so源码中实现
 
(4)实现libgps.so源码main.c
(可参考hardware/libhardware_legacy/gps/gps_qemu.c)
 
  1. static const GpsInterface sirfGpsInterface = {
  2.     sirf_gps_init,
  3.     sirf_gps_start,
  4.     sirf_gps_stop,
  5.     sirf_gps_cleanup,
  6.     sirf_gps_inject_time,
  7.     sirf_gps_inject_location,
  8.     sirf_gps_delete_aiding_data,
  9.     sirf_gps_set_position_mode,
  10.     sirf_gps_get_extension,
  11. };
  12. const GpsInterface* gps_get_hardware_interface()
  13. {
  14.     return &sirfGpsInterface;
  15. }

下面将介绍下需要修改的函数,其他函数都可以仿照gps_qemu.c

sirf_gps_start()函数中添加SiRF_Start();

sirf_gps_stop()函数中添加SiRF_Stop();

sirf_gps_init()函数中调用gps_state_init,作用是创建socket通信和gps_state_thread线程;

gps_state_init()函数中需要根据具体的GPS模块实现state->fd = channel_open();

gps_state_thread()函数中去掉两句nmea_reader_set_callback调用;

nmea_reader_parse()函数添加callbacks.nmea_cb和callbacks.location_cb:

  1. if (r->pos < 9) {
  2.         D("Too short. discarded.");
  3.         return;
  4. }
  5. {
  6.     struct timeval tv;
  7.     gettimeofday(&tv, NULL);
  8.      _gps_state->callbacks.nmea_cb(tv.tv_sec*1000+tv.tv_usec/1000, r->in, r->pos);
  9. }
  10. nmea_tokenizer_init(tzer, r->in, r->in + r->pos);
  1. if (_gps_state->callbacks.location_cb) {
  2.      _gps_state->callbacks.location_cb( &r->fix );
  3.      r->fix.flags = 0;
  4. }
  5. else {
  6.      D("no callback, keeping data until needed !");
  7. }

(5)NMEA数据上报

Android本身的GPS读取NMEA信息机制是调用read函数读取串口信息并解析上报,但SIRF提供了SiRF_Output函数用于底层与应用层的数据上报,GPS工作后会有线程不停调用SiRF_Output,因此只要在SiRF_Output函数中添加:

  1. NmeaReader reader[1];
  2. nmea_reader_init( reader );

  3. for (nn = 0; nn < sizeof(buf); nn++)
  4.      nmea_reader_addc( reader, buf[nn] );

现在GPS可以上报GGA、GSA、RMC等数据(GSA数据需添加nmea_reader_parse函数中关于GSA数据解析)

 

后面还会继续研究GSA等数据的解析上报...期待o ^-^

 

 

阅读(18549) | 评论(24) | 转发(1) |
给主人留下些什么吧!~~

Z-yalinux2011-03-21 12:59:35

你是不是使用原始版本的Android?原始版本是所以没有的,教你一个简单的方法,hardware/libhardware_legacy/gps目录下有gps_qemu.c,你参照它写自己的.c文件,可以放在同一目录下,但需要修改该目录下的Android.mk文件

tchely2011-03-21 10:11:59

Z-yalinux: 1.Android.mk位于hardware下与gps相关的目录中,BoardConfig.mk位于vendor中(每个平台不一样),具体的你要看google提供的方法,文章中有网站链接
2.打开串口用
楼主您好,我的android源码中没有vendor这个目录,我网上查了下这个目录,到现在还是不知其所以然,是不是我的android源码有问题??

Z-yalinux2011-03-21 09:49:38

tchely: 楼主你好,我刚涉及Android不久,我想问两个问题:
1.楼主你文章开始修改的那个Android.mk和BoardConfig.mk是那个文件夹下面的;
2.打开串口要怎么打开。。。.....
1.Android.mk位于hardware下与gps相关的目录中,BoardConfig.mk位于vendor中(每个平台不一样),具体的你要看google提供的方法,文章中有网站链接
2.打开串口用open函数,这和Linux下的系统调用open一样,不过我使用的是Sirf提供的打开串口函数

tchely2011-03-18 15:34:04

楼主你好,我刚涉及Android不久,我想问两个问题:
1.楼主你文章开始修改的那个Android.mk和BoardConfig.mk是那个文件夹下面的;
2.打开串口要怎么打开。。。

Z-yalinux2011-03-15 13:55:33

你可以参考下Android自带的gps_qemu.c文件,它在gps_state_init()中调用了state->fd = qemu_channel_open(),我们要根据自己的gps实现这部分代码,其实就是串口的创建打开。还有sirf_gps_start()、sirf_gps_stop()是gps的打开与关闭,不单纯只有电源的开关,也会有reset等动作,具体要根据sirf提供的库接口函数实现。