Chinaunix首页 | 论坛 | 博客
  • 博客访问: 108998
  • 博文数量: 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 ^-^

 

 

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

2011-03-12 15:07:40

博主你好,我先在也在android平台下做sirf gps的驱动集成,看了你的文章很有收获。有两个问题想请教你一下,“gps_state_init()函数中需要根据具体的GPS模块实现state->fd = channel_open()”这个我不太明白,应该怎么具体实现。还有sirf_gps_start()、sirf_gps_stop()是实现gps电源的开关吗?

sniper1672011-02-23 11:34:34

Z-yalinux: 1.读GPS数据的正常方式是串口读取数据,我也试过直接读串口,但读出来的都是乱码,估计SIRF对GPS的数据做了加密,只能用他们给的.a库和Output函数才能读到正确的
我现在是直接读取串口,能读取到NEMA数据,现在只能解析出来有12颗卫星,但是每颗卫星的db值全为0.我不知道问题出在哪。

Z-yalinux2011-02-21 11:38:45

sniper167: 顶,Z-yalinux,我也在另外一个平台做SIRF GPS的android驱动,但我老大说只要把串口打通,能够通过串口读取数据就OK,但我想没这么简单吧?另外,我见你在前一篇.....
1.读GPS数据的正常方式是串口读取数据,我也试过直接读串口,但读出来的都是乱码,估计SIRF对GPS的数据做了加密,只能用他们给的.a库和Output函数才能读到正确的信息(.a库中有打开读取串口的代码)。
2.另外,SIRF提供的库里面关于GPS打开关闭和reset使用的方法是控制sysfs模型驱动,也就是直接echo某个数字到sysfs文件,SIRF没有提供这部分代码,只能自己写。

sniper1672011-02-18 16:42:20

顶,Z-yalinux,我也在另外一个平台做SIRF GPS的android驱动,但我老大说只要把串口打通,能够通过串口读取数据就OK,但我想没这么简单吧?另外,我见你在前一篇文章提到,还需要在linux加入GPS驱动,GPS模块不都是通过串口控制么?为什么还需要加一个驱动控制?