nuttx/drivers/modem/alt1250/altcom_hdlr_other.c

217 lines
6.4 KiB
C
Raw Normal View History

/****************************************************************************
* drivers/modem/alt1250/altcom_hdlr_other.c
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
****************************************************************************/
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdint.h>
#include <stddef.h>
#include <string.h>
#include <errno.h>
#include <arpa/inet.h>
#include <nuttx/modem/alt1250.h>
#include <nuttx/wireless/lte/lte.h>
#include "alt1250.h"
#include "altcom_cmd.h"
#include "altcom_lwm2m_hdlr.h"
#include "altcom_errno.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define ATCMD_HEADER "AT"
#define ATCMD_HEADER_LEN (2)
#define ATCMD_FOOTER '\r'
#define ATCMD_FOOTER_LEN (1)
/****************************************************************************
* Public Functions
****************************************************************************/
int32_t altcom_getimei_pkt_compose(FAR void **arg, size_t arglen,
uint8_t altver, FAR uint8_t *pktbuf,
const size_t pktsz, FAR uint16_t *altcid)
{
int32_t size = 0;
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV1
if (altver == ALTCOM_VER1)
{
*altcid = APICMDID_GET_IMEI;
}
else
#endif
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV4
if (altver == ALTCOM_VER4)
{
*altcid = APICMDID_GET_IMEI_V4;
}
else
#endif
{
size = -ENOSYS;
}
return size;
}
int32_t altcom_sendatcmd_pkt_compose(FAR void **arg, size_t arglen,
uint8_t altver, FAR uint8_t *pktbuf,
const size_t pktsz,
FAR uint16_t *altcid)
{
int32_t size = 0;
FAR const char *cmd = (FAR const char *)arg[0];
int cmdlen = (int)arg[1];
size = cmdlen - ATCMD_HEADER_LEN;
memcpy(pktbuf, cmd + ATCMD_HEADER_LEN, size);
pktbuf[size - ATCMD_FOOTER_LEN] = '\0';
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV1
if (altver == ALTCOM_VER1)
{
size = -ENOTSUP;
}
else
#endif
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV4
if (altver == ALTCOM_VER4)
{
*altcid = APICMDID_SEND_ATCMD_V4;
}
else
#endif
{
size = -ENOTSUP;
}
return size;
}
int32_t altcom_errinfo_pkt_parse(FAR struct alt1250_dev_s *dev,
FAR uint8_t *pktbuf, size_t pktsz,
uint8_t altver, FAR void **arg,
size_t arglen, FAR uint64_t *bitmap)
{
FAR lte_errinfo_t *info = (FAR lte_errinfo_t *)arg[0];
FAR struct apicmd_cmddat_errinfo_s *in =
(FAR struct apicmd_cmddat_errinfo_s *)pktbuf;
info->err_indicator = in->indicator;
info->err_result_code = ntohl(in->err_code);
info->err_no = altcom_errno2nuttx(ntohl(in->err_no));
memcpy(info->err_string, in->err_str, LTE_ERROR_STRING_MAX_LEN);
info->err_string[LTE_ERROR_STRING_MAX_LEN - 1] = '\0';
return 0;
}
int32_t altcom_getimei_pkt_parse(FAR struct alt1250_dev_s *dev,
FAR uint8_t *pktbuf, size_t pktsz,
uint8_t altver, FAR void **arg,
size_t arglen, FAR uint64_t *bitmap)
{
FAR int *ret = (FAR int *)arg[0];
FAR char *imei = (FAR char *)arg[1];
FAR struct apicmd_cmddat_getimeires_s *in =
(FAR struct apicmd_cmddat_getimeires_s *)pktbuf;
*ret = (LTE_RESULT_OK == in->result) ? 0 : -EPROTO;
if (0 == *ret)
{
if (arglen > 2)
{
FAR size_t *len = (FAR size_t *)arg[2];
/* Is it enough length to include Null terminate?
* The length of LTE_IMEI_LEN includes the
* null terminator.
*/
if (*len < strnlen((FAR const char *)in->imei, LTE_IMEI_LEN))
{
return -ENOBUFS;
}
}
strncpy(imei, (FAR const char *)in->imei, LTE_IMEI_LEN);
}
return 0;
}
int32_t altcom_sendatcmd_pkt_parse(FAR struct alt1250_dev_s *dev,
FAR uint8_t *pktbuf, size_t pktsz,
uint8_t altver, FAR void **arg,
size_t arglen, FAR uint64_t *bitmap)
{
FAR char *respbuff = (FAR char *)arg[0];
FAR int respbufflen = (int)arg[1];
FAR int *resplen = (FAR int *)arg[2];
if (respbufflen < pktsz)
{
return -ENOBUFS;
}
memcpy(respbuff, (FAR char *)pktbuf, pktsz);
*resplen = pktsz;
return 0;
}
int32_t altcom_urc_event_pkt_parse(FAR struct alt1250_dev_s *dev,
FAR uint8_t *pktbuf, size_t pktsz,
uint8_t altver, FAR void **arg,
size_t arglen, FAR uint64_t *bitmap)
{
int32_t ret = -ENOTSUP;
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV4
uint32_t lcmdid = 0;
alt_evtbuf_inst_t *inst;
lwm2mstub_hndl_t lwm2m_urc_handler;
#endif
#ifndef CONFIG_MODEM_ALT1250_DISABLE_PV4
if (altver == ALTCOM_VER4)
{
pktbuf[pktsz] = '\0';
m_info("===== URC =====\n%s"
"===============\n", pktbuf);
lwm2m_urc_handler = lwm2mstub_get_handler(&pktbuf, &pktsz, &lcmdid);
*bitmap = get_event_lapibuffer(dev, lcmdid, &inst);
if (*bitmap != 0ULL)
{
ret = lwm2m_urc_handler(pktbuf, pktsz,
inst->outparam, inst->outparamlen);
}
}
#endif
return ret;
}