8. M601 系统 API 的使用

1 系统相关 API


1.1 ZYF_GetCoreVersion 获取系统版本信息
· 函数原型
int32_t ZYF_GetCoreVersion(uint8_t* ptrVer, uint32_t len)
· 参数
ptrVer:指向获取库版本的数组指针
len:必须大于等于 40,否则会返回错误代码
· 返回值
成功:返回库版本字符长度
失败:返回结果为负,具体请参考 zyf_error.h 文件中错误代码。


1.2 ZYF_SysUsDelay 函数延时,单位:微秒
· 函数原型
void ZYF_SysUsDelay (uint32_t delay)
· 参数
delay:延时时间,单位:us
· 返回值
none。


1.3 ZYF_SysMsDelay 函数延时,单位:毫秒
· 函数原型
void ZYF_SysMsDelay (uint32_t delay)
· 参数
delay:延时时间,单位:ms
· 返回值
none。

1.4 ZYF_IsSimValid 查询 SIM 卡是否有效
· 函数原型
int32_t ZYF_IsSimValid (void)
· 参数
none
· 返回值
ZYF_RET_OK: 成功
ZYF_RET_ERR_SIM_NOT_INSERTED: 未插卡或卡坏了


1.5 ZYF_GetImei 获取设备 IMEI 号
· 函数原型
int32_t ZYF_GetImei(uint8_t *imei_str, uint8_t length)
· 参数
imei_str:指向设备 IMEI 号的数组指针
length:必须大于等于 16,否则会返回错误代码
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_FATAL:失败
ZYF_RET_ERR_PARAM:参数错误


1.6 ZYF_GetImsi 获取 IMSI 号
· 函数原型
int32_t ZYF_GetImsi(uint8_t *imsi_data, uint8_t length)
· 参数
imsi_data:用来保存 SIM 卡的 IMSI 号
length:返回的数据长度
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_FATAL:失败
ZYF_RET_ERR_PARAM:参数错误

1.7 ZYF_GetIccid 获取 ICCID 
· 函数原型
int32_t ZYF_GetIccid(PsFuncPtr CallBack)
· 参数
CallBack:获取 ICCID 的回调函数,可在函数中读取 ICCID 号码
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_PARAM:参数错误


1.8 ZYF_GetCsqValue 获取设备信号值
· 函数原型
int32_t ZYF_GetCsqValue(uint8_t *csq_value)
· 参数
csq_value:获取 ICCID 的回调函数,可在函数中读取 ICCID 号码
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_FATAL:失败
ZYF_RET_ERR_PARAM:参数错误


1.9 ZYF_GetCregStatus 获取 GSM 注网状态
· 函数原型
int32_t ZYF_GetCregStatus(uint8_t *creg_status)
· 参数
creg_status:指向 uint8_t 类型变量指针,用于获取 CREG 值
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_PARAM:参数错误

1.10 ZYF_GetCgregStatus 获取 GPRS 注网状态
· 函数原型
int32_t ZYF_GetCgregStatus(uint8_t *cgreg_status, uint8_t *plmn,
uint16_t *lac_value, uint16_t *ci_value)
· 参数
cgreg_status:指向 uint8_t 类型变量指针,用于获取 CGREG 值
plmn:指向 uint8_t 类型变量指针,用于获取 plmn 值(MCC+MNC),
数组长度必须大于等于 10
lac_value:指向 uint16_t 类型变量指针,用于获取 lac 值
ci_value:指向 uint16_t 类型变量指针,用于获取 ci 值
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_PARAM:参数错误


1.11 ZYF_FlightModeOnOff 打开/ 关闭飞行模式
· 函数原型
int32_t ZYF_FlightModeOnOff(uint8_t on_off)
· 参数
on_off: TRUE: 打开飞行模式, FALSE: 关闭飞行模式
· 返回值
ZYF_RET_OK:成功
ZYF_RET_ERR_PARAM:参数错误


1.12 ZYF_MemoryTotalLeftSize 获取剩余的堆空间大小
· 函数原型
uint32_t ZYF_MemoryTotalLeftSize(void)
· 参数
none
· 返回值
剩余空间大小

2 系统例程介绍


本章节主要介绍如何在 SDK 中使用 example_system.c。
编译方法:.\examples\build\对应的.bat 文件双击执行或打开就可以编译。
生成文件:.\out\对应目录\hex\M601_example_**.pac

例程中将测试的结果打印到串口,可连接串口助手查看到测试的结果。



#include <stdlib.h>
#include <string.h>
#include "zyf_trace.h"
#include "zyf_system.h"
#include "zyf_app.h"
#include "zyf_uart.h"
#include "zyf_thread.h"
#include "zyf_time.h"

#include "zyf_error.h"


static Uart_Param_t g_uart1param;

void UartWriteCallBack(void* Param) // general com
{
    Uart_Param_t *uartparam = (Uart_Param_t *)Param; 
    if(Param == NULL)
    {
        return;
    }    

    ZYF_UartWrite(uartparam->port,(uint8_t *)"UartWrite succeed\r\n",strlen("UartWrite succeed\r\n"));
    ZYF_UartWriteCallbackSwitch(uartparam->port,false);

}

void UartReadCallBack(void* Param) // 
{
    uint32_t recvlen = 0;
    Uart_Param_t *uartparam = (Uart_Param_t *)Param; 

    ZYF_LOG("Uart%d recv",uartparam->port);

    while(ZYF_UartRead(uartparam->port, &(uartparam->uartbuf[recvlen]), 1))
    {
        ZYF_LOG("recv :%02x",uartparam->uartbuf[recvlen]);
        recvlen++;
    }
    ZYF_UartWrite(uartparam->port,uartparam->uartbuf,recvlen);
    ZYF_UartWriteCallbackSwitch(uartparam->port,true);
}


static void AppUartInit(void)
{
    int32_t ret;
    g_uart1param.port = DEBUG_PORT;
    ZYF_UartRegister(g_uart1param.port, UartReadCallBack,&g_uart1param);
    ZYF_UartWriteCbRegister(g_uart1param.port,UartWriteCallBack,&g_uart1param);
    ZYF_UartOpen(g_uart1param.port, 115200, ZYF_FC_NONE);

    ZYF_LOG("AppUartInit");
    return;
}



#if 1
static void GetIccidCallback(void*msg)
{
    uint8_t idx;


    if(NULL == msg)
    {
        ZYF_LOG("SystemApi GetIccid fail");
        return;
    }
    idx = strlen((char*)msg);
    if((idx < 3) || (idx > 20))
    {
        ZYF_LOG("SystemApi GetIccid fail,idx:%d",idx);
        return;
    }
    ZYF_LOG("SystemApi GetIccid %s",(char*)msg);
 
    
}


static void GetImsiCallback(void*msg)
{
    uint8_t idx;

    
    ZYF_LOG("GetImsiCallback");

    if(NULL == msg)
    {
        ZYF_LOG("SystemApi GetImsi fail");
        return;
    }
    idx = strlen((char*)msg);
    if((idx < 3) || (idx > 20))
    {
        ZYF_LOG("SystemApi GetImsi fail,idx:%d",idx);
        //return;
    }
    ZYF_LOG("SystemApi GetImsi %s",(char*)msg);
 
    
}

static void FlightModeOnOff(int on_off)
{
    ZYF_LOG("FlightModeOnOff %d",on_off);
}

#endif


void ZYF_SystemApiTest(void)
{
    uint8_t Imei[16+1] = {0};
    uint8_t csq = 0;
    uint8_t CregStatus = 0;
    uint8_t CgregStatus = 0,plmn[6] = {0};
    uint32_t lac_value = 0,ci_value = 0;
    uint64_t ms = 0,sec = 0;;
    uint32_t high = 0;
    uint32_t low = 0;
    int32_t nwMode = 0;

    if(0 == ZYF_IsSimValid())
    {
        ZYF_LOG("SystemApi IsSimValid:true");
    }
    else
    {
        ZYF_LOG("SystemApi IsSimValid:false");
    }

    if(ZYF_RET_OK == ZYF_GetNetworkInfo(&nwMode))
    {
        ZYF_LOG("ZYF_GetNetworkInfo:%d",nwMode);
    }
    else
    {
        ZYF_LOG("ZYF_GetNetworkInfo fail");
    }
    
    ms = ZYF_GetTickMs();
    high = (ms >> 32) & 0xFFFFFFFF;
    low = ms & 0xFFFFFFFF;
    ZYF_LOG("ZYF_GetLocalTimeMs %lu,%lu", high,low);

    sec = ZYF_GetLocalTimeSec();
    high = (sec >> 32) & 0xFFFFFFFF;
    low = sec& 0xFFFFFFFF;

    ZYF_LOG("ZYF_GetLocalTimeSec: %lu,%lu", high,low);

    //ZYF_LOG("ZYF_FlightModeOnOff:%d",ZYF_FlightModeOnOff(1,FlightModeOnOff));
    ZYF_LOG("ZYF_FlightModeIsOn:%d",ZYF_FlightModeIsOn());


    ZYF_LOG("SystemApi nwscanmode:%d",ZYF_Getnwscanmode());
    ZYF_GetImei(Imei,sizeof(Imei));
    ZYF_LOG("SystemApi Imei:%s",Imei);
    ZYF_GetCsqValue(&csq);
    ZYF_LOG("SystemApi csq:%d",csq);
    ZYF_GetCregStatus(&CregStatus);
    ZYF_LOG("SystemApi CregStatus:%d",CregStatus);

    ZYF_GetCgregStatus(&CgregStatus, plmn, &lac_value, &ci_value);
    ZYF_LOG("SystemApi CregStatus:CgregStatus:%02X,plmn:%02x%x%02x,lac_value:%X,ci_value:%X",\
                    CregStatus, plmn[0],plmn[1],plmn[2], lac_value, ci_value);

    ZYF_GetIccid(GetIccidCallback);
    ZYF_GetImsi(GetImsiCallback);

    ZYF_LOG("ZYF_SleepEnable:%d",ZYF_SleepEnable());
    
}


void SystemApiThread_Example(void * Param)
{
    ZYF_MsgQ_t *ptMsg;
    ZYF_AppMsg_t tMsg;
    int iRet = -1;
    ptMsg = ZYF_MsgQCreate(10, sizeof(ZYF_AppMsg_t));
    ZYF_LOG("thread enter!");

    ZYF_SystemApiTest();
    
    while (1) {
        ZYF_LOG("in while.");
        iRet = ZYF_MsgQGet(ptMsg, (void *)&tMsg);
        if (iRet < 0) {
            ZYF_LOG("Failed to get msg");
            ZYF_ThreadSleep(1000);
        }
    }

}

static void prvInvokeGlobalCtors(void)
{
    extern void (*__init_array_start[])();
    extern void (*__init_array_end[])();

    size_t count = __init_array_end - __init_array_start;
    for (size_t i = 0; i < count; ++i)
        __init_array_start[i]();
}


int appimg_enter(void *param)
{
    AppUartInit();
    ZYF_LOG("application image enter, param 0x%x", param);

    prvInvokeGlobalCtors();

    ZYF_ThreadCreate("UartThread_Example", SystemApiThread_Example, NULL, ZYF_PRIORITY_HIGH, 10*1024);
    return 0;
}

void appimg_exit(void)
{
    OSI_LOGI(0, "application image exit");
}








猜你喜欢

转载自blog.csdn.net/w_hizyf_m/article/details/107089085