mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-05 15:00:33 +00:00
Merge branch 'next' into ssr
This commit is contained in:
commit
c93fb481bc
@ -222,8 +222,8 @@ public:
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Returns name of RINEX observation file
|
||||
*/
|
||||
* \brief Returns name of RINEX observation file
|
||||
*/
|
||||
inline std::string get_obsfilename() const
|
||||
{
|
||||
return obsfilename;
|
||||
|
@ -192,12 +192,12 @@ public:
|
||||
int32_t read_MT1019(const std::string& message, Gps_Ephemeris& gps_eph) const;
|
||||
|
||||
/*!
|
||||
* \brief Prints message type 1020 (GLONASS Ephemeris).
|
||||
* \note Code added as part of GSoC 2017 program
|
||||
* \param glonass_gnav_eph GLONASS GNAV Broadcast Ephemeris
|
||||
* \param glonass_gnav_utc_model GLONASS GNAV Clock Information
|
||||
* \return Returns message type as a string type
|
||||
*/
|
||||
* \brief Prints message type 1020 (GLONASS Ephemeris).
|
||||
* \note Code added as part of GSoC 2017 program
|
||||
* \param glonass_gnav_eph GLONASS GNAV Broadcast Ephemeris
|
||||
* \param glonass_gnav_utc_model GLONASS GNAV Clock Information
|
||||
* \return Returns message type as a string type
|
||||
*/
|
||||
std::string print_MT1020(const Glonass_Gnav_Ephemeris& glonass_gnav_eph, const Glonass_Gnav_Utc_Model& glonass_gnav_utc_model);
|
||||
|
||||
/*!
|
||||
|
@ -88,8 +88,8 @@ public:
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
inline void set_channel_fsm(std::weak_ptr<ChannelFsm> channel_fsm) override
|
||||
{
|
||||
channel_fsm_ = channel_fsm;
|
||||
|
@ -89,8 +89,8 @@ public:
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
inline void set_channel_fsm(std::weak_ptr<ChannelFsm> channel_fsm) override
|
||||
{
|
||||
channel_fsm_ = channel_fsm;
|
||||
|
@ -89,8 +89,8 @@ public:
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
* \brief Set channel fsm associated to this acquisition instance
|
||||
*/
|
||||
inline void set_channel_fsm(std::weak_ptr<ChannelFsm> channel_fsm) override
|
||||
{
|
||||
channel_fsm_ = channel_fsm;
|
||||
|
@ -38,8 +38,8 @@ namespace own = gsl;
|
||||
|
||||
|
||||
/*!
|
||||
* \brief Generates Galileo E6B code at 1 sample/chip
|
||||
*/
|
||||
* \brief Generates Galileo E6B code at 1 sample/chip
|
||||
*/
|
||||
void galileo_e6_b_code_gen_complex_primary(own::span<std::complex<float>> dest,
|
||||
int32_t prn);
|
||||
|
||||
@ -51,9 +51,9 @@ void galileo_e6_b_code_gen_float_primary(own::span<float> dest, int32_t prn);
|
||||
|
||||
|
||||
/*!
|
||||
* \brief Generates Galileo E6B complex code, shifted to the desired chip and
|
||||
* sampled at a frequency sampling_freq
|
||||
*/
|
||||
* \brief Generates Galileo E6B complex code, shifted to the desired chip and
|
||||
* sampled at a frequency sampling_freq
|
||||
*/
|
||||
void galileo_e6_b_code_gen_complex_sampled(own::span<std::complex<float>> dest,
|
||||
uint32_t prn,
|
||||
int32_t sampling_freq,
|
||||
|
@ -60,30 +60,30 @@ double prange(const obsd_t *obs, const nav_t *nav, const double *azel,
|
||||
int iter, const prcopt_t *opt, double *var);
|
||||
|
||||
/* ionospheric correction ------------------------------------------------------
|
||||
* compute ionospheric correction
|
||||
* args : gtime_t time I time
|
||||
* nav_t *nav I navigation data
|
||||
* int sat I satellite number
|
||||
* double *pos I receiver position {lat,lon,h} (rad|m)
|
||||
* double *azel I azimuth/elevation angle {az,el} (rad)
|
||||
* int ionoopt I ionospheric correction option (IONOOPT_???)
|
||||
* double *ion O ionospheric delay (L1) (m)
|
||||
* double *var O ionospheric delay (L1) variance (m^2)
|
||||
* return : status(1:ok,0:error)
|
||||
*-----------------------------------------------------------------------------*/
|
||||
* compute ionospheric correction
|
||||
* args : gtime_t time I time
|
||||
* nav_t *nav I navigation data
|
||||
* int sat I satellite number
|
||||
* double *pos I receiver position {lat,lon,h} (rad|m)
|
||||
* double *azel I azimuth/elevation angle {az,el} (rad)
|
||||
* int ionoopt I ionospheric correction option (IONOOPT_???)
|
||||
* double *ion O ionospheric delay (L1) (m)
|
||||
* double *var O ionospheric delay (L1) variance (m^2)
|
||||
* return : status(1:ok,0:error)
|
||||
*-----------------------------------------------------------------------------*/
|
||||
int ionocorr(gtime_t time, const nav_t *nav, int sat, const double *pos,
|
||||
const double *azel, int ionoopt, double *ion, double *var);
|
||||
/* tropospheric correction -----------------------------------------------------
|
||||
* compute tropospheric correction
|
||||
* args : gtime_t time I time
|
||||
* nav_t *nav I navigation data
|
||||
* double *pos I receiver position {lat,lon,h} (rad|m)
|
||||
* double *azel I azimuth/elevation angle {az,el} (rad)
|
||||
* int tropopt I tropospheric correction option (TROPOPT_???)
|
||||
* double *trp O tropospheric delay (m)
|
||||
* double *var O tropospheric delay variance (m^2)
|
||||
* return : status(1:ok,0:error)
|
||||
*-----------------------------------------------------------------------------*/
|
||||
* compute tropospheric correction
|
||||
* args : gtime_t time I time
|
||||
* nav_t *nav I navigation data
|
||||
* double *pos I receiver position {lat,lon,h} (rad|m)
|
||||
* double *azel I azimuth/elevation angle {az,el} (rad)
|
||||
* int tropopt I tropospheric correction option (TROPOPT_???)
|
||||
* double *trp O tropospheric delay (m)
|
||||
* double *var O tropospheric delay variance (m^2)
|
||||
* return : status(1:ok,0:error)
|
||||
*-----------------------------------------------------------------------------*/
|
||||
int tropcorr(gtime_t time, const nav_t *nav, const double *pos,
|
||||
const double *azel, int tropopt, double *trp, double *var);
|
||||
|
||||
@ -122,22 +122,22 @@ void estvel(const obsd_t *obs, int n, const double *rs, const double *dts,
|
||||
const double *azel, const int *vsat);
|
||||
|
||||
/*!
|
||||
* \brief single-point positioning
|
||||
* compute receiver position, velocity, clock bias by single-point positioning
|
||||
* with pseudorange and doppler observables
|
||||
* args : obsd_t *obs I observation data
|
||||
* int n I number of observation data
|
||||
* nav_t *nav I navigation data
|
||||
* prcopt_t *opt I processing options
|
||||
* sol_t *sol IO solution
|
||||
* double *azel IO azimuth/elevation angle (rad) (NULL: no output)
|
||||
* ssat_t *ssat IO satellite status (NULL: no output)
|
||||
* char *msg O error message for error exit
|
||||
* return : status(1:ok,0:error)
|
||||
* notes : assuming sbas-gps, galileo-gps, qzss-gps, compass-gps time offset and
|
||||
* receiver bias are negligible (only involving glonass-gps time offset
|
||||
* and receiver bias)
|
||||
*/
|
||||
* \brief single-point positioning
|
||||
* compute receiver position, velocity, clock bias by single-point positioning
|
||||
* with pseudorange and doppler observables
|
||||
* args : obsd_t *obs I observation data
|
||||
* int n I number of observation data
|
||||
* nav_t *nav I navigation data
|
||||
* prcopt_t *opt I processing options
|
||||
* sol_t *sol IO solution
|
||||
* double *azel IO azimuth/elevation angle (rad) (NULL: no output)
|
||||
* ssat_t *ssat IO satellite status (NULL: no output)
|
||||
* char *msg O error message for error exit
|
||||
* return : status(1:ok,0:error)
|
||||
* notes : assuming sbas-gps, galileo-gps, qzss-gps, compass-gps time offset and
|
||||
* receiver bias are negligible (only involving glonass-gps time offset
|
||||
* and receiver bias)
|
||||
*/
|
||||
int pntpos(const obsd_t *obs, int n, const nav_t *nav,
|
||||
const prcopt_t *opt, sol_t *sol, double *azel, ssat_t *ssat,
|
||||
char *msg);
|
||||
|
@ -118,9 +118,9 @@ static const PPCInfo kEmptyPPCInfo;
|
||||
PPCInfo GetPPCInfo(void)
|
||||
{
|
||||
/*
|
||||
* On Power feature flags aren't currently in cpuinfo so we only look at
|
||||
* the auxilary vector.
|
||||
*/
|
||||
* On Power feature flags aren't currently in cpuinfo so we only look at
|
||||
* the auxilary vector.
|
||||
*/
|
||||
PPCInfo info = kEmptyPPCInfo;
|
||||
const HardwareCapabilities hwcaps = CpuFeatures_GetHardwareCapabilities();
|
||||
for (size_t i = 0; i < PPC_LAST_; ++i)
|
||||
|
@ -95,9 +95,9 @@ size_t volk_gnsssdr_load_preferences(volk_gnsssdr_arch_pref_t **prefs_res)
|
||||
|
||||
// get the config path
|
||||
volk_gnsssdr_get_config_path(path, true);
|
||||
if (!path[0]) return n_arch_prefs; //no prefs found
|
||||
if (!path[0]) return n_arch_prefs; // no prefs found
|
||||
config_file = fopen(path, "r");
|
||||
if (!config_file) return n_arch_prefs; //no prefs found
|
||||
if (!config_file) return n_arch_prefs; // no prefs found
|
||||
|
||||
// reset the file pointer and write the prefs into volk_gnsssdr_arch_prefs
|
||||
while (fgets(line, sizeof(line), config_file) != NULL)
|
||||
|
@ -32,7 +32,7 @@ int volk_gnsssdr_get_index(
|
||||
// TODO return -1;
|
||||
// something terrible should happen here
|
||||
fprintf(stderr, "VOLK_GNSSSDR warning: no arch found, returning generic impl\n");
|
||||
return volk_gnsssdr_get_index(impl_names, n_impls, "generic"); //but we'll fake it for now
|
||||
return volk_gnsssdr_get_index(impl_names, n_impls, "generic"); // but we'll fake it for now
|
||||
}
|
||||
|
||||
|
||||
@ -66,7 +66,7 @@ int volk_gnsssdr_rank_archs(
|
||||
// now look for the function name in the prefs list
|
||||
for (i = 0; i < n_arch_prefs; i++)
|
||||
{
|
||||
if (!strncmp(kern_name, volk_gnsssdr_arch_prefs[i].name, sizeof(volk_gnsssdr_arch_prefs[i].name))) //found it
|
||||
if (!strncmp(kern_name, volk_gnsssdr_arch_prefs[i].name, sizeof(volk_gnsssdr_arch_prefs[i].name))) // found it
|
||||
{
|
||||
const char *impl_name = align ? volk_gnsssdr_arch_prefs[i].impl_a : volk_gnsssdr_arch_prefs[i].impl_u;
|
||||
return volk_gnsssdr_get_index(impl_names, n_impls, impl_name);
|
||||
|
@ -47,7 +47,7 @@ struct volk_gnsssdr_machine *get_machine(void)
|
||||
}
|
||||
}
|
||||
machine = max_machine;
|
||||
//printf("Using Volk machine: %s\n", machine->name);
|
||||
// printf("Using Volk machine: %s\n", machine->name);
|
||||
__alignment = machine->alignment;
|
||||
__alignment_mask = (intptr_t)(__alignment - 1);
|
||||
return machine;
|
||||
@ -101,7 +101,7 @@ const char *volk_gnsssdr_get_machine(void)
|
||||
|
||||
size_t volk_gnsssdr_get_alignment(void)
|
||||
{
|
||||
get_machine(); //ensures alignment is set
|
||||
get_machine(); // ensures alignment is set
|
||||
return __alignment;
|
||||
}
|
||||
|
||||
|
@ -22,16 +22,16 @@ struct VOLK_CPU volk_gnsssdr_cpu;
|
||||
|
||||
#if defined(VOLK_CPU_x86)
|
||||
|
||||
//implement get cpuid for gcc compilers using a system or local copy of cpuid.h
|
||||
// implement get cpuid for gcc compilers using a system or local copy of cpuid.h
|
||||
#if defined(__GNUC__)
|
||||
#include <cpuid.h>
|
||||
#define cpuid_x86(op, r) __get_cpuid(op, (unsigned int *)r + 0, (unsigned int *)r + 1, (unsigned int *)r + 2, (unsigned int *)r + 3)
|
||||
#define cpuid_x86_count(op, count, regs) __cpuid_count(op, count, *((unsigned int *)regs), *((unsigned int *)regs + 1), *((unsigned int *)regs + 2), *((unsigned int *)regs + 3))
|
||||
|
||||
/* Return Intel AVX extended CPU capabilities register.
|
||||
* This function will bomb on non-AVX-capable machines, so
|
||||
* check for AVX capability before executing.
|
||||
*/
|
||||
* This function will bomb on non-AVX-capable machines, so
|
||||
* check for AVX capability before executing.
|
||||
*/
|
||||
#if ((__GNUC__ > 4 || __GNUC__ == 4 && __GNUC_MINOR__ >= 2) || (__clang_major__ >= 3)) && defined(HAVE_XGETBV)
|
||||
static inline unsigned long long _xgetbv(unsigned int index)
|
||||
{
|
||||
@ -46,7 +46,7 @@ static inline unsigned long long _xgetbv(unsigned int index)
|
||||
#define __xgetbv() 0
|
||||
#endif
|
||||
|
||||
//implement get cpuid for MSVC compilers using __cpuid intrinsic
|
||||
// implement get cpuid for MSVC compilers using __cpuid intrinsic
|
||||
#elif defined(_MSC_VER) && defined(HAVE_INTRIN_H)
|
||||
#include <intrin.h>
|
||||
#define cpuid_x86(op, r) __cpuid(((int *)r), op)
|
||||
@ -60,9 +60,9 @@ static inline unsigned long long _xgetbv(unsigned int index)
|
||||
|
||||
#else
|
||||
#error "A get cpuid for volk_gnsssdr is not available on this compiler..."
|
||||
#endif //defined(__GNUC__)
|
||||
#endif // defined(__GNUC__)
|
||||
|
||||
#endif //defined(VOLK_CPU_x86)
|
||||
#endif // defined(VOLK_CPU_x86)
|
||||
|
||||
static inline unsigned int cpuid_count_x86_bit(unsigned int level, unsigned int count, unsigned int reg, unsigned int bit)
|
||||
{
|
||||
@ -120,13 +120,13 @@ static inline unsigned int get_avx2_enabled(void)
|
||||
static inline unsigned int get_avx512_enabled(void)
|
||||
{
|
||||
#if defined(VOLK_CPU_x86)
|
||||
return __xgetbv() & 0xE6; //check for zmm, xmm and ymm regs
|
||||
return __xgetbv() & 0xE6; // check for zmm, xmm and ymm regs
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
//neon detection is linux specific
|
||||
// neon detection is linux specific
|
||||
#if defined(__arm__) && defined(__linux__)
|
||||
#include <asm/hwcap.h>
|
||||
#include <linux/auxvec.h>
|
||||
@ -144,8 +144,8 @@ static int has_neonv7(void)
|
||||
if (!auxvec_f) return 0;
|
||||
|
||||
size_t r = 1;
|
||||
//so auxv is basically 32b of ID and 32b of value
|
||||
//so it goes like this
|
||||
// so auxv is basically 32b of ID and 32b of value
|
||||
// so it goes like this
|
||||
while (!found_neon && r)
|
||||
{
|
||||
r = fread(auxvec, sizeof(unsigned long), 2, auxvec_f);
|
||||
@ -161,7 +161,7 @@ static int has_neonv7(void)
|
||||
}
|
||||
|
||||
//\todo: Fix this to really check for neon on aarch64
|
||||
//neon detection is linux specific
|
||||
// neon detection is linux specific
|
||||
#if defined(__aarch64__) && defined(__linux__)
|
||||
#include <asm/hwcap.h>
|
||||
#include <linux/auxvec.h>
|
||||
@ -179,8 +179,8 @@ static int has_neonv8(void)
|
||||
if (!auxvec_f) return 0;
|
||||
|
||||
size_t r = 1;
|
||||
//so auxv is basically 32b of ID and 32b of value
|
||||
//so it goes like this
|
||||
// so auxv is basically 32b of ID and 32b of value
|
||||
// so it goes like this
|
||||
while (!found_neon && r)
|
||||
{
|
||||
r = fread(auxvec, sizeof(unsigned long), 2, auxvec_f);
|
||||
@ -225,7 +225,7 @@ static int i_can_has_${arch.name} (void) {
|
||||
}
|
||||
#else
|
||||
static inline void set_float_rounding(void){
|
||||
//do nothing
|
||||
// do nothing
|
||||
}
|
||||
#endif
|
||||
#elif defined(_MSC_VER)
|
||||
@ -237,7 +237,7 @@ static int i_can_has_${arch.name} (void) {
|
||||
}
|
||||
#else
|
||||
static inline void set_float_rounding(void){
|
||||
//do nothing
|
||||
// do nothing
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -33,9 +33,9 @@
|
||||
class ConfigurationInterface;
|
||||
|
||||
/*!
|
||||
* \brief This class generates synthesized GNSS signal.
|
||||
*
|
||||
*/
|
||||
* \brief This class generates synthesized GNSS signal.
|
||||
*
|
||||
*/
|
||||
class SignalGenerator : public GNSSBlockInterface
|
||||
{
|
||||
public:
|
||||
|
@ -35,9 +35,9 @@
|
||||
|
||||
|
||||
/*
|
||||
* Create a new instance of signal_generator_c and return
|
||||
* a boost shared_ptr. This is effectively the public constructor.
|
||||
*/
|
||||
* Create a new instance of signal_generator_c and return
|
||||
* a boost shared_ptr. This is effectively the public constructor.
|
||||
*/
|
||||
signal_generator_c_sptr
|
||||
signal_make_generator_c(const std::vector<std::string> &signal1, const std::vector<std::string> &system, const std::vector<unsigned int> &PRN,
|
||||
const std::vector<float> &CN0_dB, const std::vector<float> &doppler_Hz,
|
||||
@ -50,8 +50,8 @@ signal_make_generator_c(const std::vector<std::string> &signal1, const std::vect
|
||||
|
||||
|
||||
/*
|
||||
* The private constructor
|
||||
*/
|
||||
* The private constructor
|
||||
*/
|
||||
signal_generator_c::signal_generator_c(std::vector<std::string> signal1,
|
||||
std::vector<std::string> system,
|
||||
const std::vector<unsigned int> &PRN,
|
||||
|
@ -29,12 +29,12 @@ class signal_generator_c;
|
||||
using signal_generator_c_sptr = gnss_shared_ptr<signal_generator_c>;
|
||||
|
||||
/*!
|
||||
* \brief Return a shared_ptr to a new instance of gen_source.
|
||||
*
|
||||
* To avoid accidental use of raw pointers, gen_source's
|
||||
* constructor is private. signal_make_generator_c is the public
|
||||
* interface for creating new instances.
|
||||
*/
|
||||
* \brief Return a shared_ptr to a new instance of gen_source.
|
||||
*
|
||||
* To avoid accidental use of raw pointers, gen_source's
|
||||
* constructor is private. signal_make_generator_c is the public
|
||||
* interface for creating new instances.
|
||||
*/
|
||||
signal_generator_c_sptr signal_make_generator_c(
|
||||
const std::vector<std::string> &signal1,
|
||||
const std::vector<std::string> &system,
|
||||
@ -50,11 +50,11 @@ signal_generator_c_sptr signal_make_generator_c(
|
||||
float BW_BB);
|
||||
|
||||
/*!
|
||||
* \brief This class generates synthesized GNSS signal.
|
||||
* \ingroup block
|
||||
*
|
||||
* \sa gen_source for a version that subclasses gr_block.
|
||||
*/
|
||||
* \brief This class generates synthesized GNSS signal.
|
||||
* \ingroup block
|
||||
*
|
||||
* \sa gen_source for a version that subclasses gr_block.
|
||||
*/
|
||||
class signal_generator_c : public gr::block
|
||||
{
|
||||
public:
|
||||
|
@ -50,10 +50,10 @@ glonass_l2_ca_telemetry_decoder_gs_sptr glonass_l2_ca_make_telemetry_decoder_gs(
|
||||
const Tlm_Conf &conf);
|
||||
|
||||
/*!
|
||||
* \brief This class implements a block that decodes the GNAV data defined in GLONASS ICD v5.1
|
||||
* \see <a href="http://russianspacesystems.ru/wp-content/uploads/2016/08/ICD_GLONASS_eng_v5.1.pdf">GLONASS ICD</a>
|
||||
*
|
||||
*/
|
||||
* \brief This class implements a block that decodes the GNAV data defined in GLONASS ICD v5.1
|
||||
* \see <a href="http://russianspacesystems.ru/wp-content/uploads/2016/08/ICD_GLONASS_eng_v5.1.pdf">GLONASS ICD</a>
|
||||
*
|
||||
*/
|
||||
class glonass_l2_ca_telemetry_decoder_gs : public gr::block
|
||||
{
|
||||
public:
|
||||
@ -63,8 +63,8 @@ public:
|
||||
inline void reset(){};
|
||||
|
||||
/*!
|
||||
* \brief This is where all signal processing takes place
|
||||
*/
|
||||
* \brief This is where all signal processing takes place
|
||||
*/
|
||||
int general_work(int noutput_items, gr_vector_int &ninput_items,
|
||||
gr_vector_const_void_star &input_items, gr_vector_void_star &output_items) override;
|
||||
|
||||
|
@ -1,22 +1,22 @@
|
||||
/*!
|
||||
* \file gps_l1_ca_telemetry_decoder_gs.cc
|
||||
* \brief Implementation of a NAV message demodulator block based on
|
||||
* Kay Borre book MATLAB-based GPS receiver
|
||||
* \author Javier Arribas, 2011. jarribas(at)cttc.es
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*
|
||||
* Copyright (C) 2010-2020 (see AUTHORS file for a list of contributors)
|
||||
*
|
||||
* GNSS-SDR is a software defined Global Navigation
|
||||
* Satellite Systems receiver
|
||||
*
|
||||
* This file is part of GNSS-SDR.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*/
|
||||
* \file gps_l1_ca_telemetry_decoder_gs.cc
|
||||
* \brief Implementation of a NAV message demodulator block based on
|
||||
* Kay Borre book MATLAB-based GPS receiver
|
||||
* \author Javier Arribas, 2011. jarribas(at)cttc.es
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*
|
||||
* Copyright (C) 2010-2020 (see AUTHORS file for a list of contributors)
|
||||
*
|
||||
* GNSS-SDR is a software defined Global Navigation
|
||||
* Satellite Systems receiver
|
||||
*
|
||||
* This file is part of GNSS-SDR.
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#include "gps_l1_ca_telemetry_decoder_gs.h"
|
||||
#include "gnss_sdr_make_unique.h" // for std::make_unique in C++11
|
||||
|
@ -76,14 +76,14 @@ typedef struct
|
||||
/**< Decode buffer */
|
||||
size_t n_decoded; /**< Number of bits in the decode buffer */
|
||||
bool preamble_seen; /**< When true, the decode buffer is aligned on
|
||||
* preamble. */
|
||||
* preamble. */
|
||||
bool invert; /**< When true, indicates the bits are inverted */
|
||||
bool message_lock; /**< When true, indicates the message boundary
|
||||
* is found. */
|
||||
* is found. */
|
||||
bool crc_ok; /**< Flag that the last message had good CRC */
|
||||
size_t n_crc_fail; /**< Counter for CRC failures */
|
||||
bool init; /**< Initial state flag. When true, initial bits
|
||||
* do not produce output. */
|
||||
* do not produce output. */
|
||||
} cnav_v27_part_t;
|
||||
|
||||
/**
|
||||
|
@ -37,18 +37,18 @@ public:
|
||||
~Tlm_CRC_Stats();
|
||||
|
||||
/*!
|
||||
* \brief Initialize the telemetry CRC statistics
|
||||
*/
|
||||
* \brief Initialize the telemetry CRC statistics
|
||||
*/
|
||||
void initialize(std::string dump_crc_stats_filename_);
|
||||
|
||||
/*!
|
||||
* \brief Initialize the channel number and output file
|
||||
*/
|
||||
* \brief Initialize the channel number and output file
|
||||
*/
|
||||
bool set_channel(int32_t channel_);
|
||||
|
||||
/*!
|
||||
* \brief Update the CRC statistics
|
||||
*/
|
||||
* \brief Update the CRC statistics
|
||||
*/
|
||||
void update_CRC_stats(bool CRC);
|
||||
|
||||
private:
|
||||
|
@ -570,9 +570,9 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
|
||||
else if (state == ST_DIGITS)
|
||||
{
|
||||
/* The colon here means that we have
|
||||
* decoded the first two hexadecimal
|
||||
* places as a decimal value.
|
||||
* Switch decoding mode. */
|
||||
* decoded the first two hexadecimal
|
||||
* places as a decimal value.
|
||||
* Switch decoding mode. */
|
||||
ASN_DEBUG("INTEGER re-evaluate as hex form");
|
||||
if (INTEGER_st_prealloc(st,
|
||||
(chunk_size / 3) + 1))
|
||||
|
@ -224,8 +224,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* Check tags.
|
||||
*/
|
||||
* Check tags.
|
||||
*/
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, buf_ptr, size,
|
||||
tag_mode, -1, &ctx->left, &tlv_constr);
|
||||
if (rval.code != RC_OK)
|
||||
@ -236,8 +236,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (tlv_constr)
|
||||
{
|
||||
/*
|
||||
* Complex operation, requires stack of expectations.
|
||||
*/
|
||||
* Complex operation, requires stack of expectations.
|
||||
*/
|
||||
ctx->ptr = new_stack();
|
||||
if (ctx->ptr)
|
||||
{
|
||||
@ -251,8 +251,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* Jump into stackless primitive decoding.
|
||||
*/
|
||||
* Jump into stackless primitive decoding.
|
||||
*/
|
||||
_CH_PHASE(ctx, 3);
|
||||
if (type_variant == ASN_OSUBV_ANY && tag_mode != 1)
|
||||
{
|
||||
@ -267,8 +267,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case 1:
|
||||
phase1:
|
||||
/*
|
||||
* Fill the stack with expectations.
|
||||
*/
|
||||
* Fill the stack with expectations.
|
||||
*/
|
||||
stck = (struct stack *)ctx->ptr;
|
||||
sel = stck->cur_ptr;
|
||||
do
|
||||
@ -383,9 +383,9 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Set up expected tags,
|
||||
* depending on ASN.1 type being decoded.
|
||||
*/
|
||||
* Set up expected tags,
|
||||
* depending on ASN.1 type being decoded.
|
||||
*/
|
||||
switch (type_variant)
|
||||
{
|
||||
case ASN_OSUBV_BIT:
|
||||
@ -444,8 +444,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Append a new expectation.
|
||||
*/
|
||||
* Append a new expectation.
|
||||
*/
|
||||
sel = OS__add_stack_el(stck);
|
||||
if (!sel)
|
||||
{
|
||||
@ -548,8 +548,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case 3:
|
||||
phase3:
|
||||
/*
|
||||
* Primitive form, no stack required.
|
||||
*/
|
||||
* Primitive form, no stack required.
|
||||
*/
|
||||
assert(ctx->left >= 0);
|
||||
|
||||
if (size < (size_t)ctx->left)
|
||||
@ -1513,8 +1513,8 @@ static int OCTET_STRING_per_get_characters(asn_per_data_t *po, uint8_t *buf,
|
||||
{
|
||||
return 1;
|
||||
} /* FATAL: can't have constrained
|
||||
* UniversalString with more than
|
||||
* 16 million code points */
|
||||
* UniversalString with more than
|
||||
* 16 million code points */
|
||||
for (; buf < end; buf += bpc)
|
||||
{
|
||||
int value;
|
||||
|
@ -289,26 +289,26 @@ asn_dec_rval_t xer_decode_primitive(
|
||||
"Primitive body is not recognized, "
|
||||
"supplying empty one");
|
||||
/*
|
||||
* Decoding opportunity has come and gone.
|
||||
* Where's the result?
|
||||
* Try to feed with empty body, see if it eats it.
|
||||
*/
|
||||
* Decoding opportunity has come and gone.
|
||||
* Where's the result?
|
||||
* Try to feed with empty body, see if it eats it.
|
||||
*/
|
||||
if (prim_body_decoder(s_arg.type_descriptor,
|
||||
s_arg.struct_key, &ch,
|
||||
0) != XPBD_BODY_CONSUMED)
|
||||
{
|
||||
/*
|
||||
* This decoder does not like empty stuff.
|
||||
*/
|
||||
* This decoder does not like empty stuff.
|
||||
*/
|
||||
_ASN_DECODE_FAILED;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case RC_WMORE:
|
||||
/*
|
||||
* Redo the whole thing later.
|
||||
* We don't have a context to save intermediate parsing state.
|
||||
*/
|
||||
* Redo the whole thing later.
|
||||
* We don't have a context to save intermediate parsing state.
|
||||
*/
|
||||
rc.consumed = 0;
|
||||
break;
|
||||
case RC_FAIL:
|
||||
|
@ -164,10 +164,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
if (tag_mode || td->tags_count)
|
||||
{
|
||||
@ -200,8 +200,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
ASN_DEBUG("In %s CHOICE tag length %d", td->name, (int)tag_len);
|
||||
switch (tag_len)
|
||||
@ -228,8 +228,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (t2m)
|
||||
{
|
||||
/*
|
||||
* Found the element corresponding to the tag.
|
||||
*/
|
||||
* Found the element corresponding to the tag.
|
||||
*/
|
||||
NEXT_PHASE(ctx);
|
||||
ctx->step = t2m->el_no;
|
||||
break;
|
||||
@ -275,9 +275,9 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
|
||||
case 2:
|
||||
/*
|
||||
* PHASE 2.
|
||||
* Read in the element.
|
||||
*/
|
||||
* PHASE 2.
|
||||
* Read in the element.
|
||||
*/
|
||||
do
|
||||
{
|
||||
asn_TYPE_member_t *elm; /* CHOICE's element */
|
||||
@ -287,10 +287,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
elm = &elements[ctx->step];
|
||||
|
||||
/*
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
if (elm->flags & ATF_POINTER)
|
||||
{
|
||||
/* Member is a pointer to another structure */
|
||||
@ -300,20 +300,20 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
memb_ptr = (char *)st + elm->memb_offset;
|
||||
memb_ptr2 = &memb_ptr;
|
||||
}
|
||||
/* Set presence to be able to free it properly at any
|
||||
* time */
|
||||
* time */
|
||||
set_present_idx(st, specs->pres_offset,
|
||||
specs->pres_size, ctx->step + 1);
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elm->type->ber_decoder(opt_codec_ctx, elm->type,
|
||||
memb_ptr2, ptr, LEFT,
|
||||
elm->tag_mode);
|
||||
@ -347,27 +347,27 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (ctx->left > 0)
|
||||
{
|
||||
/*
|
||||
* The type must be fully decoded
|
||||
* by the CHOICE member-specific decoder.
|
||||
*/
|
||||
* The type must be fully decoded
|
||||
* by the CHOICE member-specific decoder.
|
||||
*/
|
||||
RETURN(RC_FAIL);
|
||||
}
|
||||
|
||||
if (ctx->left == -1 && !(tag_mode || td->tags_count))
|
||||
{
|
||||
/*
|
||||
* This is an untagged CHOICE.
|
||||
* It doesn't contain nothing
|
||||
* except for the member itself, including all its tags.
|
||||
* The decoding is completed.
|
||||
*/
|
||||
* This is an untagged CHOICE.
|
||||
* It doesn't contain nothing
|
||||
* except for the member itself, including all its tags.
|
||||
* The decoding is completed.
|
||||
*/
|
||||
NEXT_PHASE(ctx);
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* Read in the "end of data chunks"'s.
|
||||
*/
|
||||
* Read in the "end of data chunks"'s.
|
||||
*/
|
||||
while (ctx->left < 0)
|
||||
{
|
||||
ssize_t tl;
|
||||
@ -386,8 +386,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Expected <0><0>...
|
||||
*/
|
||||
* Expected <0><0>...
|
||||
*/
|
||||
if (((const uint8_t *)ptr)[0] == 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -404,8 +404,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
ADVANCE(2);
|
||||
ctx->left++;
|
||||
continue;
|
||||
@ -852,8 +852,8 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Search which inner member corresponds to this tag.
|
||||
*/
|
||||
* Search which inner member corresponds to this tag.
|
||||
*/
|
||||
for (edx = 0; edx < td->elements_count; edx++)
|
||||
{
|
||||
elm = &td->elements[edx];
|
||||
@ -864,8 +864,8 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case XCT_BOTH:
|
||||
case XCT_OPENING:
|
||||
/*
|
||||
* Process this member.
|
||||
*/
|
||||
* Process this member.
|
||||
*/
|
||||
ctx->step = edx;
|
||||
ctx->phase = 2;
|
||||
break;
|
||||
@ -888,10 +888,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
ASN_DEBUG("Got anticipated extension");
|
||||
/*
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
if (tcv & XCT_CLOSING)
|
||||
{
|
||||
/* Found </extension> without body */
|
||||
|
@ -178,10 +178,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, ptr, size,
|
||||
tag_mode, 1, &ctx->left, 0);
|
||||
@ -206,15 +206,15 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next member from the list of
|
||||
* this structure's elements.
|
||||
* (ctx->step) stores the member being processed
|
||||
* between invocations and the microphase {0,1} of parsing
|
||||
* that member:
|
||||
* step = (<member_number> * 2 + <microphase>).
|
||||
*/
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next member from the list of
|
||||
* this structure's elements.
|
||||
* (ctx->step) stores the member being processed
|
||||
* between invocations and the microphase {0,1} of parsing
|
||||
* that member:
|
||||
* step = (<member_number> * 2 + <microphase>).
|
||||
*/
|
||||
for (edx = (ctx->step >> 1); edx < td->elements_count;
|
||||
edx++, ctx->step = (ctx->step & ~1) + 2)
|
||||
{
|
||||
@ -231,8 +231,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
ASN_DEBUG(
|
||||
"In %s SEQUENCE left %d, edx=%d flags=%d"
|
||||
" opt=%d ec=%d",
|
||||
@ -251,15 +251,15 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
ASN_DEBUG("End of SEQUENCE %s", td->name);
|
||||
/*
|
||||
* Found the legitimate end of the structure.
|
||||
*/
|
||||
* Found the legitimate end of the structure.
|
||||
*/
|
||||
PHASE_OUT(ctx);
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
ASN_DEBUG(
|
||||
"Current tag in %s SEQUENCE for element %d "
|
||||
@ -304,23 +304,23 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
td->elements_count))
|
||||
{
|
||||
/*
|
||||
* Yeah, baby! Found the
|
||||
* terminator of the indefinite
|
||||
* length structure.
|
||||
*/
|
||||
* Yeah, baby! Found the
|
||||
* terminator of the indefinite
|
||||
* length structure.
|
||||
*/
|
||||
/*
|
||||
* Proceed to the canonical
|
||||
* finalization function.
|
||||
* No advancing is necessary.
|
||||
*/
|
||||
* Proceed to the canonical
|
||||
* finalization function.
|
||||
* No advancing is necessary.
|
||||
*/
|
||||
goto phase3;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Find the next available type with this tag.
|
||||
*/
|
||||
* Find the next available type with this tag.
|
||||
*/
|
||||
use_bsearch = 0;
|
||||
opt_edx_end = edx + elements[edx].optional + 1;
|
||||
if (opt_edx_end > td->elements_count)
|
||||
@ -339,10 +339,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (BER_TAGS_EQUAL(tlv_tag, elements[n].tag))
|
||||
{
|
||||
/*
|
||||
* Found element corresponding to the
|
||||
* tag being looked at. Reposition over
|
||||
* the right element.
|
||||
*/
|
||||
* Found element corresponding to the
|
||||
* tag being looked at. Reposition over
|
||||
* the right element.
|
||||
*/
|
||||
edx = n;
|
||||
ctx->step = 1 + 2 * edx; /* Remember! */
|
||||
goto microphase2;
|
||||
@ -350,9 +350,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (elements[n].flags & ATF_OPEN_TYPE)
|
||||
{
|
||||
/*
|
||||
* This is the ANY type, which may bear
|
||||
* any flag whatsoever.
|
||||
*/
|
||||
* This is the ANY type, which may bear
|
||||
* any flag whatsoever.
|
||||
*/
|
||||
edx = n;
|
||||
ctx->step = 1 + 2 * edx; /* Remember! */
|
||||
goto microphase2;
|
||||
@ -366,9 +366,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (use_bsearch)
|
||||
{
|
||||
/*
|
||||
* Resort to a binary search over
|
||||
* sorted array of tags.
|
||||
*/
|
||||
* Resort to a binary search over
|
||||
* sorted array of tags.
|
||||
*/
|
||||
asn_TYPE_tag2member_t *t2m;
|
||||
asn_TYPE_tag2member_t key;
|
||||
key.el_tag = tlv_tag;
|
||||
@ -384,10 +384,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
int edx_max =
|
||||
edx + elements[edx].optional;
|
||||
/*
|
||||
* Rewind to the first element with that
|
||||
* tag, `cause bsearch() does not
|
||||
* guarantee order.
|
||||
*/
|
||||
* Rewind to the first element with that
|
||||
* tag, `cause bsearch() does not
|
||||
* guarantee order.
|
||||
*/
|
||||
t2m_f = t2m + t2m->toff_first;
|
||||
t2m_l = t2m + t2m->toff_last;
|
||||
for (t2m = t2m_f; t2m <= t2m_l; t2m++)
|
||||
@ -414,11 +414,11 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (n == opt_edx_end)
|
||||
{
|
||||
/*
|
||||
* If tag is unknown, it may be either
|
||||
* an unknown (thus, incorrect) tag,
|
||||
* or an extension (...),
|
||||
* or an end of the indefinite-length structure.
|
||||
*/
|
||||
* If tag is unknown, it may be either
|
||||
* an unknown (thus, incorrect) tag,
|
||||
* or an extension (...),
|
||||
* or an end of the indefinite-length structure.
|
||||
*/
|
||||
if (!IN_EXTENSION_GROUP(
|
||||
specs, edx + elements[edx].optional))
|
||||
{
|
||||
@ -466,22 +466,22 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
ctx->step -= 2;
|
||||
edx--;
|
||||
continue; /* Try again with the next tag
|
||||
*/
|
||||
*/
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
ctx->step |= 1; /* Confirm entering next microphase */
|
||||
microphase2:
|
||||
ASN_DEBUG("Inside SEQUENCE %s MF2", td->name);
|
||||
|
||||
/*
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
if (elements[edx].flags & ATF_POINTER)
|
||||
{
|
||||
/* Member is a pointer to another structure */
|
||||
@ -492,17 +492,17 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
memb_ptr =
|
||||
(char *)st + elements[edx].memb_offset;
|
||||
memb_ptr2 = &memb_ptr;
|
||||
}
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elements[edx].type->ber_decoder(
|
||||
opt_codec_ctx, elements[edx].type, memb_ptr2, ptr,
|
||||
LEFT, elements[edx].tag_mode);
|
||||
@ -541,8 +541,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
(long)ctx->left, (long)size);
|
||||
|
||||
/*
|
||||
* Skip everything until the end of the SEQUENCE.
|
||||
*/
|
||||
* Skip everything until the end of the SEQUENCE.
|
||||
*/
|
||||
while (ctx->left)
|
||||
{
|
||||
ssize_t tl;
|
||||
@ -562,8 +562,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* If expected <0><0>...
|
||||
*/
|
||||
* If expected <0><0>...
|
||||
*/
|
||||
if (ctx->left < 0 && ((const uint8_t *)ptr)[0] == 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -580,8 +580,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
ADVANCE(2);
|
||||
ctx->left++;
|
||||
ctx->phase = 4;
|
||||
@ -724,8 +724,8 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
|
||||
if (computed_size != 0)
|
||||
{
|
||||
/*
|
||||
* Encoded size is not equal to the computed size.
|
||||
*/
|
||||
* Encoded size is not equal to the computed size.
|
||||
*/
|
||||
_ASN_ENCODE_FAILED;
|
||||
}
|
||||
|
||||
@ -902,7 +902,7 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
if (edx >= td->elements_count ||
|
||||
/* Explicit OPTIONAL specs reaches the end
|
||||
*/
|
||||
*/
|
||||
(edx + elements[edx].optional ==
|
||||
td->elements_count) ||
|
||||
/* All extensions are optional */
|
||||
@ -942,8 +942,8 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (edx < td->elements_count)
|
||||
{
|
||||
/*
|
||||
* Search which member corresponds to this tag.
|
||||
*/
|
||||
* Search which member corresponds to this tag.
|
||||
*/
|
||||
edx_end = edx + elements[edx].optional + 1;
|
||||
if (edx_end > td->elements_count)
|
||||
{
|
||||
@ -959,8 +959,8 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case XCT_BOTH:
|
||||
case XCT_OPENING:
|
||||
/*
|
||||
* Process this member.
|
||||
*/
|
||||
* Process this member.
|
||||
*/
|
||||
ctx->step = edx = n;
|
||||
ctx->phase = 2;
|
||||
break;
|
||||
@ -993,10 +993,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
ASN_DEBUG("Got anticipated extension at %d",
|
||||
edx);
|
||||
/*
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
if (tcv & XCT_CLOSING)
|
||||
{
|
||||
/* Found </extension> without body */
|
||||
|
@ -124,10 +124,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, ptr, size,
|
||||
tag_mode, 1, &ctx->left, 0);
|
||||
@ -153,10 +153,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next item.
|
||||
*/
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next item.
|
||||
*/
|
||||
for (;; ctx->step = 0)
|
||||
{
|
||||
ssize_t tag_len; /* Length of TLV's T */
|
||||
@ -167,23 +167,23 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
|
||||
if (ctx->left == 0)
|
||||
{
|
||||
ASN_DEBUG("End of SET OF %s", td->name);
|
||||
/*
|
||||
* No more things to decode.
|
||||
* Exit out of here.
|
||||
*/
|
||||
* No more things to decode.
|
||||
* Exit out of here.
|
||||
*/
|
||||
PHASE_OUT(ctx);
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
switch (tag_len)
|
||||
{
|
||||
@ -213,23 +213,23 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Found the terminator of the
|
||||
* indefinite length structure.
|
||||
*/
|
||||
* Found the terminator of the
|
||||
* indefinite length structure.
|
||||
*/
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Outmost tag may be unknown and cannot be
|
||||
* fetched/compared */
|
||||
* fetched/compared */
|
||||
if (elm->tag != (ber_tlv_tag_t)-1)
|
||||
{
|
||||
if (BER_TAGS_EQUAL(tlv_tag, elm->tag))
|
||||
{
|
||||
/*
|
||||
* The new list member of expected type
|
||||
* has arrived.
|
||||
*/
|
||||
* The new list member of expected type
|
||||
* has arrived.
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -245,15 +245,15 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
ctx->step |= 1; /* Confirm entering next microphase */
|
||||
microphase2:
|
||||
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elm->type->ber_decoder(opt_codec_ctx, elm->type,
|
||||
&ctx->ptr, ptr, LEFT, 0);
|
||||
ASN_DEBUG("In %s SET OF %s code %d consumed %d",
|
||||
@ -294,8 +294,8 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
NEXT_PHASE(ctx);
|
||||
case 2:
|
||||
/*
|
||||
* Read in all "end of content" TLVs.
|
||||
*/
|
||||
* Read in all "end of content" TLVs.
|
||||
*/
|
||||
while (ctx->left < 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -726,8 +726,8 @@ asn_dec_rval_t SET_OF_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (ctx->phase == 1)
|
||||
{
|
||||
/*
|
||||
* Process a single possible member.
|
||||
*/
|
||||
* Process a single possible member.
|
||||
*/
|
||||
ctx->phase = 2;
|
||||
continue;
|
||||
}
|
||||
|
@ -292,12 +292,12 @@ asn_dec_rval_t xer_decode_general(
|
||||
if (ctx->phase == 0)
|
||||
{
|
||||
/*
|
||||
* We have to ignore whitespace
|
||||
* here, but in order to be forward
|
||||
* compatible with EXTENDED-XER
|
||||
* (EMBED-VALUES, #25) any text is
|
||||
* just ignored here.
|
||||
*/
|
||||
* We have to ignore whitespace
|
||||
* here, but in order to be forward
|
||||
* compatible with EXTENDED-XER
|
||||
* (EMBED-VALUES, #25) any text is
|
||||
* just ignored here.
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -351,8 +351,8 @@ asn_dec_rval_t xer_decode_general(
|
||||
RETURN(RC_OK);
|
||||
case XCT_UNKNOWN_BO:
|
||||
/*
|
||||
* Certain tags in the body may be expected.
|
||||
*/
|
||||
* Certain tags in the body may be expected.
|
||||
*/
|
||||
if (opt_unexpected_tag_decoder &&
|
||||
opt_unexpected_tag_decoder(struct_key, buf_ptr,
|
||||
ch_size) >= 0)
|
||||
@ -362,7 +362,7 @@ asn_dec_rval_t xer_decode_general(
|
||||
if (!ctx->phase)
|
||||
{
|
||||
/* We are not expecting
|
||||
* the closing tag anymore. */
|
||||
* the closing tag anymore. */
|
||||
ctx->phase = 2; /* Phase out */
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
@ -390,11 +390,11 @@ int xer_is_whitespace(const void *chunk_buf, size_t chunk_size)
|
||||
switch (*p)
|
||||
{
|
||||
/* X.693, #8.1.4
|
||||
* HORISONTAL TAB (9)
|
||||
* LINE FEED (10)
|
||||
* CARRIAGE RETURN (13)
|
||||
* SPACE (32)
|
||||
*/
|
||||
* HORISONTAL TAB (9)
|
||||
* LINE FEED (10)
|
||||
* CARRIAGE RETURN (13)
|
||||
* SPACE (32)
|
||||
*/
|
||||
case 0x09:
|
||||
case 0x0a:
|
||||
case 0x0d:
|
||||
|
@ -103,9 +103,9 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
{
|
||||
case ST_TEXT:
|
||||
/*
|
||||
* Initial state: we're in the middle of some text,
|
||||
* or just have started.
|
||||
*/
|
||||
* Initial state: we're in the middle of some text,
|
||||
* or just have started.
|
||||
*/
|
||||
if (C == LANGLE)
|
||||
{ /* We're now in the tag, probably */
|
||||
TOKEN_CB(PXML_TEXT, ST_TAG_START, 0);
|
||||
@ -138,10 +138,10 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case LANGLE:
|
||||
/*
|
||||
* The previous tag wasn't completed, but
|
||||
* still recognized as valid.
|
||||
* (Mozilla-compatible)
|
||||
*/
|
||||
* The previous tag wasn't completed, but
|
||||
* still recognized as valid.
|
||||
* (Mozilla-compatible)
|
||||
*/
|
||||
TOKEN_CB_FINAL(PXML_TAG, ST_TAG_START, 0);
|
||||
break;
|
||||
case CEQUAL:
|
||||
@ -151,8 +151,8 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case ST_TAG_QUOTE_WAIT:
|
||||
/*
|
||||
* State after the equal sign ("=") in the tag.
|
||||
*/
|
||||
* State after the equal sign ("=") in the tag.
|
||||
*/
|
||||
switch (C)
|
||||
{
|
||||
case CQUOTE:
|
||||
@ -172,8 +172,8 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case ST_TAG_QUOTED_STRING:
|
||||
/*
|
||||
* Tag attribute's string value in quotes.
|
||||
*/
|
||||
* Tag attribute's string value in quotes.
|
||||
*/
|
||||
if (C == CQUOTE)
|
||||
{
|
||||
/* Return back to the tag state */
|
||||
@ -240,7 +240,7 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
else if (C == CDASH)
|
||||
{
|
||||
/* Maintain current state, still waiting for '>'
|
||||
*/
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -549,8 +549,8 @@ time_t asn_GT2time_frac(const GeneralizedTime_t *st, int *frac_value,
|
||||
case 0x2C:
|
||||
case 0x2E: /* (.|,) */
|
||||
/*
|
||||
* Process fractions of seconds.
|
||||
*/
|
||||
* Process fractions of seconds.
|
||||
*/
|
||||
for (buf++; buf < end; buf++)
|
||||
{
|
||||
int v = *buf;
|
||||
|
@ -570,9 +570,9 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
|
||||
else if (state == ST_DIGITS)
|
||||
{
|
||||
/* The colon here means that we have
|
||||
* decoded the first two hexadecimal
|
||||
* places as a decimal value.
|
||||
* Switch decoding mode. */
|
||||
* decoded the first two hexadecimal
|
||||
* places as a decimal value.
|
||||
* Switch decoding mode. */
|
||||
ASN_DEBUG("INTEGER re-evaluate as hex form");
|
||||
if (INTEGER_st_prealloc(st,
|
||||
(chunk_size / 3) + 1))
|
||||
|
@ -224,8 +224,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* Check tags.
|
||||
*/
|
||||
* Check tags.
|
||||
*/
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, buf_ptr, size,
|
||||
tag_mode, -1, &ctx->left, &tlv_constr);
|
||||
if (rval.code != RC_OK)
|
||||
@ -236,8 +236,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (tlv_constr)
|
||||
{
|
||||
/*
|
||||
* Complex operation, requires stack of expectations.
|
||||
*/
|
||||
* Complex operation, requires stack of expectations.
|
||||
*/
|
||||
ctx->ptr = new_stack();
|
||||
if (ctx->ptr)
|
||||
{
|
||||
@ -251,8 +251,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* Jump into stackless primitive decoding.
|
||||
*/
|
||||
* Jump into stackless primitive decoding.
|
||||
*/
|
||||
_CH_PHASE(ctx, 3);
|
||||
if (type_variant == ASN_OSUBV_ANY && tag_mode != 1)
|
||||
{
|
||||
@ -267,8 +267,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case 1:
|
||||
phase1:
|
||||
/*
|
||||
* Fill the stack with expectations.
|
||||
*/
|
||||
* Fill the stack with expectations.
|
||||
*/
|
||||
stck = (struct stack *)ctx->ptr;
|
||||
sel = stck->cur_ptr;
|
||||
do
|
||||
@ -383,9 +383,9 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Set up expected tags,
|
||||
* depending on ASN.1 type being decoded.
|
||||
*/
|
||||
* Set up expected tags,
|
||||
* depending on ASN.1 type being decoded.
|
||||
*/
|
||||
switch (type_variant)
|
||||
{
|
||||
case ASN_OSUBV_BIT:
|
||||
@ -444,8 +444,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Append a new expectation.
|
||||
*/
|
||||
* Append a new expectation.
|
||||
*/
|
||||
sel = OS__add_stack_el(stck);
|
||||
if (!sel)
|
||||
{
|
||||
@ -548,8 +548,8 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case 3:
|
||||
phase3:
|
||||
/*
|
||||
* Primitive form, no stack required.
|
||||
*/
|
||||
* Primitive form, no stack required.
|
||||
*/
|
||||
assert(ctx->left >= 0);
|
||||
|
||||
if (size < (size_t)ctx->left)
|
||||
@ -1513,8 +1513,8 @@ static int OCTET_STRING_per_get_characters(asn_per_data_t *po, uint8_t *buf,
|
||||
{
|
||||
return 1;
|
||||
} /* FATAL: can't have constrained
|
||||
* UniversalString with more than
|
||||
* 16 million code points */
|
||||
* UniversalString with more than
|
||||
* 16 million code points */
|
||||
for (; buf < end; buf += bpc)
|
||||
{
|
||||
int value;
|
||||
|
@ -289,26 +289,26 @@ asn_dec_rval_t xer_decode_primitive(
|
||||
"Primitive body is not recognized, "
|
||||
"supplying empty one");
|
||||
/*
|
||||
* Decoding opportunity has come and gone.
|
||||
* Where's the result?
|
||||
* Try to feed with empty body, see if it eats it.
|
||||
*/
|
||||
* Decoding opportunity has come and gone.
|
||||
* Where's the result?
|
||||
* Try to feed with empty body, see if it eats it.
|
||||
*/
|
||||
if (prim_body_decoder(s_arg.type_descriptor,
|
||||
s_arg.struct_key, &ch,
|
||||
0) != XPBD_BODY_CONSUMED)
|
||||
{
|
||||
/*
|
||||
* This decoder does not like empty stuff.
|
||||
*/
|
||||
* This decoder does not like empty stuff.
|
||||
*/
|
||||
_ASN_DECODE_FAILED;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case RC_WMORE:
|
||||
/*
|
||||
* Redo the whole thing later.
|
||||
* We don't have a context to save intermediate parsing state.
|
||||
*/
|
||||
* Redo the whole thing later.
|
||||
* We don't have a context to save intermediate parsing state.
|
||||
*/
|
||||
rc.consumed = 0;
|
||||
break;
|
||||
case RC_FAIL:
|
||||
|
@ -164,10 +164,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
if (tag_mode || td->tags_count)
|
||||
{
|
||||
@ -200,8 +200,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
ASN_DEBUG("In %s CHOICE tag length %d", td->name, (int)tag_len);
|
||||
switch (tag_len)
|
||||
@ -228,8 +228,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (t2m)
|
||||
{
|
||||
/*
|
||||
* Found the element corresponding to the tag.
|
||||
*/
|
||||
* Found the element corresponding to the tag.
|
||||
*/
|
||||
NEXT_PHASE(ctx);
|
||||
ctx->step = t2m->el_no;
|
||||
break;
|
||||
@ -275,9 +275,9 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
|
||||
case 2:
|
||||
/*
|
||||
* PHASE 2.
|
||||
* Read in the element.
|
||||
*/
|
||||
* PHASE 2.
|
||||
* Read in the element.
|
||||
*/
|
||||
do
|
||||
{
|
||||
asn_TYPE_member_t *elm; /* CHOICE's element */
|
||||
@ -287,10 +287,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
elm = &elements[ctx->step];
|
||||
|
||||
/*
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
if (elm->flags & ATF_POINTER)
|
||||
{
|
||||
/* Member is a pointer to another structure */
|
||||
@ -300,20 +300,20 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
memb_ptr = (char *)st + elm->memb_offset;
|
||||
memb_ptr2 = &memb_ptr;
|
||||
}
|
||||
/* Set presence to be able to free it properly at any
|
||||
* time */
|
||||
* time */
|
||||
set_present_idx(st, specs->pres_offset,
|
||||
specs->pres_size, ctx->step + 1);
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elm->type->ber_decoder(opt_codec_ctx, elm->type,
|
||||
memb_ptr2, ptr, LEFT,
|
||||
elm->tag_mode);
|
||||
@ -347,27 +347,27 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (ctx->left > 0)
|
||||
{
|
||||
/*
|
||||
* The type must be fully decoded
|
||||
* by the CHOICE member-specific decoder.
|
||||
*/
|
||||
* The type must be fully decoded
|
||||
* by the CHOICE member-specific decoder.
|
||||
*/
|
||||
RETURN(RC_FAIL);
|
||||
}
|
||||
|
||||
if (ctx->left == -1 && !(tag_mode || td->tags_count))
|
||||
{
|
||||
/*
|
||||
* This is an untagged CHOICE.
|
||||
* It doesn't contain nothing
|
||||
* except for the member itself, including all its tags.
|
||||
* The decoding is completed.
|
||||
*/
|
||||
* This is an untagged CHOICE.
|
||||
* It doesn't contain nothing
|
||||
* except for the member itself, including all its tags.
|
||||
* The decoding is completed.
|
||||
*/
|
||||
NEXT_PHASE(ctx);
|
||||
break;
|
||||
}
|
||||
|
||||
/*
|
||||
* Read in the "end of data chunks"'s.
|
||||
*/
|
||||
* Read in the "end of data chunks"'s.
|
||||
*/
|
||||
while (ctx->left < 0)
|
||||
{
|
||||
ssize_t tl;
|
||||
@ -386,8 +386,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Expected <0><0>...
|
||||
*/
|
||||
* Expected <0><0>...
|
||||
*/
|
||||
if (((const uint8_t *)ptr)[0] == 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -404,8 +404,8 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
ADVANCE(2);
|
||||
ctx->left++;
|
||||
continue;
|
||||
@ -852,8 +852,8 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* Search which inner member corresponds to this tag.
|
||||
*/
|
||||
* Search which inner member corresponds to this tag.
|
||||
*/
|
||||
for (edx = 0; edx < td->elements_count; edx++)
|
||||
{
|
||||
elm = &td->elements[edx];
|
||||
@ -864,8 +864,8 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case XCT_BOTH:
|
||||
case XCT_OPENING:
|
||||
/*
|
||||
* Process this member.
|
||||
*/
|
||||
* Process this member.
|
||||
*/
|
||||
ctx->step = edx;
|
||||
ctx->phase = 2;
|
||||
break;
|
||||
@ -888,10 +888,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
ASN_DEBUG("Got anticipated extension");
|
||||
/*
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
if (tcv & XCT_CLOSING)
|
||||
{
|
||||
/* Found </extension> without body */
|
||||
|
@ -178,10 +178,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, ptr, size,
|
||||
tag_mode, 1, &ctx->left, 0);
|
||||
@ -206,15 +206,15 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next member from the list of
|
||||
* this structure's elements.
|
||||
* (ctx->step) stores the member being processed
|
||||
* between invocations and the microphase {0,1} of parsing
|
||||
* that member:
|
||||
* step = (<member_number> * 2 + <microphase>).
|
||||
*/
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next member from the list of
|
||||
* this structure's elements.
|
||||
* (ctx->step) stores the member being processed
|
||||
* between invocations and the microphase {0,1} of parsing
|
||||
* that member:
|
||||
* step = (<member_number> * 2 + <microphase>).
|
||||
*/
|
||||
for (edx = (ctx->step >> 1); edx < td->elements_count;
|
||||
edx++, ctx->step = (ctx->step & ~1) + 2)
|
||||
{
|
||||
@ -231,8 +231,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
ASN_DEBUG(
|
||||
"In %s SEQUENCE left %d, edx=%d flags=%d"
|
||||
" opt=%d ec=%d",
|
||||
@ -251,15 +251,15 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
ASN_DEBUG("End of SEQUENCE %s", td->name);
|
||||
/*
|
||||
* Found the legitimate end of the structure.
|
||||
*/
|
||||
* Found the legitimate end of the structure.
|
||||
*/
|
||||
PHASE_OUT(ctx);
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
ASN_DEBUG(
|
||||
"Current tag in %s SEQUENCE for element %d "
|
||||
@ -304,23 +304,23 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
td->elements_count))
|
||||
{
|
||||
/*
|
||||
* Yeah, baby! Found the
|
||||
* terminator of the indefinite
|
||||
* length structure.
|
||||
*/
|
||||
* Yeah, baby! Found the
|
||||
* terminator of the indefinite
|
||||
* length structure.
|
||||
*/
|
||||
/*
|
||||
* Proceed to the canonical
|
||||
* finalization function.
|
||||
* No advancing is necessary.
|
||||
*/
|
||||
* Proceed to the canonical
|
||||
* finalization function.
|
||||
* No advancing is necessary.
|
||||
*/
|
||||
goto phase3;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Find the next available type with this tag.
|
||||
*/
|
||||
* Find the next available type with this tag.
|
||||
*/
|
||||
use_bsearch = 0;
|
||||
opt_edx_end = edx + elements[edx].optional + 1;
|
||||
if (opt_edx_end > td->elements_count)
|
||||
@ -339,10 +339,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (BER_TAGS_EQUAL(tlv_tag, elements[n].tag))
|
||||
{
|
||||
/*
|
||||
* Found element corresponding to the
|
||||
* tag being looked at. Reposition over
|
||||
* the right element.
|
||||
*/
|
||||
* Found element corresponding to the
|
||||
* tag being looked at. Reposition over
|
||||
* the right element.
|
||||
*/
|
||||
edx = n;
|
||||
ctx->step = 1 + 2 * edx; /* Remember! */
|
||||
goto microphase2;
|
||||
@ -350,9 +350,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (elements[n].flags & ATF_OPEN_TYPE)
|
||||
{
|
||||
/*
|
||||
* This is the ANY type, which may bear
|
||||
* any flag whatsoever.
|
||||
*/
|
||||
* This is the ANY type, which may bear
|
||||
* any flag whatsoever.
|
||||
*/
|
||||
edx = n;
|
||||
ctx->step = 1 + 2 * edx; /* Remember! */
|
||||
goto microphase2;
|
||||
@ -366,9 +366,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (use_bsearch)
|
||||
{
|
||||
/*
|
||||
* Resort to a binary search over
|
||||
* sorted array of tags.
|
||||
*/
|
||||
* Resort to a binary search over
|
||||
* sorted array of tags.
|
||||
*/
|
||||
asn_TYPE_tag2member_t *t2m;
|
||||
asn_TYPE_tag2member_t key;
|
||||
key.el_tag = tlv_tag;
|
||||
@ -384,10 +384,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
int edx_max =
|
||||
edx + elements[edx].optional;
|
||||
/*
|
||||
* Rewind to the first element with that
|
||||
* tag, `cause bsearch() does not
|
||||
* guarantee order.
|
||||
*/
|
||||
* Rewind to the first element with that
|
||||
* tag, `cause bsearch() does not
|
||||
* guarantee order.
|
||||
*/
|
||||
t2m_f = t2m + t2m->toff_first;
|
||||
t2m_l = t2m + t2m->toff_last;
|
||||
for (t2m = t2m_f; t2m <= t2m_l; t2m++)
|
||||
@ -414,11 +414,11 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (n == opt_edx_end)
|
||||
{
|
||||
/*
|
||||
* If tag is unknown, it may be either
|
||||
* an unknown (thus, incorrect) tag,
|
||||
* or an extension (...),
|
||||
* or an end of the indefinite-length structure.
|
||||
*/
|
||||
* If tag is unknown, it may be either
|
||||
* an unknown (thus, incorrect) tag,
|
||||
* or an extension (...),
|
||||
* or an end of the indefinite-length structure.
|
||||
*/
|
||||
if (!IN_EXTENSION_GROUP(
|
||||
specs, edx + elements[edx].optional))
|
||||
{
|
||||
@ -466,22 +466,22 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
ctx->step -= 2;
|
||||
edx--;
|
||||
continue; /* Try again with the next tag
|
||||
*/
|
||||
*/
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
ctx->step |= 1; /* Confirm entering next microphase */
|
||||
microphase2:
|
||||
ASN_DEBUG("Inside SEQUENCE %s MF2", td->name);
|
||||
|
||||
/*
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
* Compute the position of the member inside a
|
||||
* structure, and also a type of containment (it may be
|
||||
* contained as pointer or using inline inclusion).
|
||||
*/
|
||||
if (elements[edx].flags & ATF_POINTER)
|
||||
{
|
||||
/* Member is a pointer to another structure */
|
||||
@ -492,17 +492,17 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else
|
||||
{
|
||||
/*
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
* A pointer to a pointer
|
||||
* holding the start of the structure
|
||||
*/
|
||||
memb_ptr =
|
||||
(char *)st + elements[edx].memb_offset;
|
||||
memb_ptr2 = &memb_ptr;
|
||||
}
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elements[edx].type->ber_decoder(
|
||||
opt_codec_ctx, elements[edx].type, memb_ptr2, ptr,
|
||||
LEFT, elements[edx].tag_mode);
|
||||
@ -541,8 +541,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
(long)ctx->left, (long)size);
|
||||
|
||||
/*
|
||||
* Skip everything until the end of the SEQUENCE.
|
||||
*/
|
||||
* Skip everything until the end of the SEQUENCE.
|
||||
*/
|
||||
while (ctx->left)
|
||||
{
|
||||
ssize_t tl;
|
||||
@ -562,8 +562,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* If expected <0><0>...
|
||||
*/
|
||||
* If expected <0><0>...
|
||||
*/
|
||||
if (ctx->left < 0 && ((const uint8_t *)ptr)[0] == 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -580,8 +580,8 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
* Correctly finished with <0><0>.
|
||||
*/
|
||||
ADVANCE(2);
|
||||
ctx->left++;
|
||||
ctx->phase = 4;
|
||||
@ -724,8 +724,8 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
|
||||
if (computed_size != 0)
|
||||
{
|
||||
/*
|
||||
* Encoded size is not equal to the computed size.
|
||||
*/
|
||||
* Encoded size is not equal to the computed size.
|
||||
*/
|
||||
_ASN_ENCODE_FAILED;
|
||||
}
|
||||
|
||||
@ -902,7 +902,7 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
if (edx >= td->elements_count ||
|
||||
/* Explicit OPTIONAL specs reaches the end
|
||||
*/
|
||||
*/
|
||||
(edx + elements[edx].optional ==
|
||||
td->elements_count) ||
|
||||
/* All extensions are optional */
|
||||
@ -942,8 +942,8 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (edx < td->elements_count)
|
||||
{
|
||||
/*
|
||||
* Search which member corresponds to this tag.
|
||||
*/
|
||||
* Search which member corresponds to this tag.
|
||||
*/
|
||||
edx_end = edx + elements[edx].optional + 1;
|
||||
if (edx_end > td->elements_count)
|
||||
{
|
||||
@ -959,8 +959,8 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
case XCT_BOTH:
|
||||
case XCT_OPENING:
|
||||
/*
|
||||
* Process this member.
|
||||
*/
|
||||
* Process this member.
|
||||
*/
|
||||
ctx->step = edx = n;
|
||||
ctx->phase = 2;
|
||||
break;
|
||||
@ -993,10 +993,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
ASN_DEBUG("Got anticipated extension at %d",
|
||||
edx);
|
||||
/*
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
* Check for (XCT_BOTH or XCT_UNKNOWN_BO)
|
||||
* By using a mask. Only record a pure
|
||||
* <opening> tags.
|
||||
*/
|
||||
if (tcv & XCT_CLOSING)
|
||||
{
|
||||
/* Found </extension> without body */
|
||||
|
@ -124,10 +124,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
{
|
||||
case 0:
|
||||
/*
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
* PHASE 0.
|
||||
* Check that the set of tags associated with given structure
|
||||
* perfectly fits our expectations.
|
||||
*/
|
||||
|
||||
rval = ber_check_tags(opt_codec_ctx, td, ctx, ptr, size,
|
||||
tag_mode, 1, &ctx->left, 0);
|
||||
@ -153,10 +153,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
/* Fall through */
|
||||
case 1:
|
||||
/*
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next item.
|
||||
*/
|
||||
* PHASE 1.
|
||||
* From the place where we've left it previously,
|
||||
* try to decode the next item.
|
||||
*/
|
||||
for (;; ctx->step = 0)
|
||||
{
|
||||
ssize_t tag_len; /* Length of TLV's T */
|
||||
@ -167,23 +167,23 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
* MICROPHASE 1: Synchronize decoding.
|
||||
*/
|
||||
|
||||
if (ctx->left == 0)
|
||||
{
|
||||
ASN_DEBUG("End of SET OF %s", td->name);
|
||||
/*
|
||||
* No more things to decode.
|
||||
* Exit out of here.
|
||||
*/
|
||||
* No more things to decode.
|
||||
* Exit out of here.
|
||||
*/
|
||||
PHASE_OUT(ctx);
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
* Fetch the T from TLV.
|
||||
*/
|
||||
tag_len = ber_fetch_tag(ptr, LEFT, &tlv_tag);
|
||||
switch (tag_len)
|
||||
{
|
||||
@ -213,23 +213,23 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
else if (((const uint8_t *)ptr)[1] == 0)
|
||||
{
|
||||
/*
|
||||
* Found the terminator of the
|
||||
* indefinite length structure.
|
||||
*/
|
||||
* Found the terminator of the
|
||||
* indefinite length structure.
|
||||
*/
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Outmost tag may be unknown and cannot be
|
||||
* fetched/compared */
|
||||
* fetched/compared */
|
||||
if (elm->tag != (ber_tlv_tag_t)-1)
|
||||
{
|
||||
if (BER_TAGS_EQUAL(tlv_tag, elm->tag))
|
||||
{
|
||||
/*
|
||||
* The new list member of expected type
|
||||
* has arrived.
|
||||
*/
|
||||
* The new list member of expected type
|
||||
* has arrived.
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -245,15 +245,15 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
}
|
||||
|
||||
/*
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
* MICROPHASE 2: Invoke the member-specific decoder.
|
||||
*/
|
||||
ctx->step |= 1; /* Confirm entering next microphase */
|
||||
microphase2:
|
||||
|
||||
/*
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
* Invoke the member fetch routine according to member's
|
||||
* type
|
||||
*/
|
||||
rval = elm->type->ber_decoder(opt_codec_ctx, elm->type,
|
||||
&ctx->ptr, ptr, LEFT, 0);
|
||||
ASN_DEBUG("In %s SET OF %s code %d consumed %d",
|
||||
@ -294,8 +294,8 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
|
||||
NEXT_PHASE(ctx);
|
||||
case 2:
|
||||
/*
|
||||
* Read in all "end of content" TLVs.
|
||||
*/
|
||||
* Read in all "end of content" TLVs.
|
||||
*/
|
||||
while (ctx->left < 0)
|
||||
{
|
||||
if (LEFT < 2)
|
||||
@ -726,8 +726,8 @@ asn_dec_rval_t SET_OF_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
|
||||
if (ctx->phase == 1)
|
||||
{
|
||||
/*
|
||||
* Process a single possible member.
|
||||
*/
|
||||
* Process a single possible member.
|
||||
*/
|
||||
ctx->phase = 2;
|
||||
continue;
|
||||
}
|
||||
|
@ -292,12 +292,12 @@ asn_dec_rval_t xer_decode_general(
|
||||
if (ctx->phase == 0)
|
||||
{
|
||||
/*
|
||||
* We have to ignore whitespace
|
||||
* here, but in order to be forward
|
||||
* compatible with EXTENDED-XER
|
||||
* (EMBED-VALUES, #25) any text is
|
||||
* just ignored here.
|
||||
*/
|
||||
* We have to ignore whitespace
|
||||
* here, but in order to be forward
|
||||
* compatible with EXTENDED-XER
|
||||
* (EMBED-VALUES, #25) any text is
|
||||
* just ignored here.
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -351,8 +351,8 @@ asn_dec_rval_t xer_decode_general(
|
||||
RETURN(RC_OK);
|
||||
case XCT_UNKNOWN_BO:
|
||||
/*
|
||||
* Certain tags in the body may be expected.
|
||||
*/
|
||||
* Certain tags in the body may be expected.
|
||||
*/
|
||||
if (opt_unexpected_tag_decoder &&
|
||||
opt_unexpected_tag_decoder(struct_key, buf_ptr,
|
||||
ch_size) >= 0)
|
||||
@ -362,7 +362,7 @@ asn_dec_rval_t xer_decode_general(
|
||||
if (!ctx->phase)
|
||||
{
|
||||
/* We are not expecting
|
||||
* the closing tag anymore. */
|
||||
* the closing tag anymore. */
|
||||
ctx->phase = 2; /* Phase out */
|
||||
RETURN(RC_OK);
|
||||
}
|
||||
@ -390,11 +390,11 @@ int xer_is_whitespace(const void *chunk_buf, size_t chunk_size)
|
||||
switch (*p)
|
||||
{
|
||||
/* X.693, #8.1.4
|
||||
* HORISONTAL TAB (9)
|
||||
* LINE FEED (10)
|
||||
* CARRIAGE RETURN (13)
|
||||
* SPACE (32)
|
||||
*/
|
||||
* HORISONTAL TAB (9)
|
||||
* LINE FEED (10)
|
||||
* CARRIAGE RETURN (13)
|
||||
* SPACE (32)
|
||||
*/
|
||||
case 0x09:
|
||||
case 0x0a:
|
||||
case 0x0d:
|
||||
|
@ -103,9 +103,9 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
{
|
||||
case ST_TEXT:
|
||||
/*
|
||||
* Initial state: we're in the middle of some text,
|
||||
* or just have started.
|
||||
*/
|
||||
* Initial state: we're in the middle of some text,
|
||||
* or just have started.
|
||||
*/
|
||||
if (C == LANGLE)
|
||||
{ /* We're now in the tag, probably */
|
||||
TOKEN_CB(PXML_TEXT, ST_TAG_START, 0);
|
||||
@ -138,10 +138,10 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case LANGLE:
|
||||
/*
|
||||
* The previous tag wasn't completed, but
|
||||
* still recognized as valid.
|
||||
* (Mozilla-compatible)
|
||||
*/
|
||||
* The previous tag wasn't completed, but
|
||||
* still recognized as valid.
|
||||
* (Mozilla-compatible)
|
||||
*/
|
||||
TOKEN_CB_FINAL(PXML_TAG, ST_TAG_START, 0);
|
||||
break;
|
||||
case CEQUAL:
|
||||
@ -151,8 +151,8 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case ST_TAG_QUOTE_WAIT:
|
||||
/*
|
||||
* State after the equal sign ("=") in the tag.
|
||||
*/
|
||||
* State after the equal sign ("=") in the tag.
|
||||
*/
|
||||
switch (C)
|
||||
{
|
||||
case CQUOTE:
|
||||
@ -172,8 +172,8 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
break;
|
||||
case ST_TAG_QUOTED_STRING:
|
||||
/*
|
||||
* Tag attribute's string value in quotes.
|
||||
*/
|
||||
* Tag attribute's string value in quotes.
|
||||
*/
|
||||
if (C == CQUOTE)
|
||||
{
|
||||
/* Return back to the tag state */
|
||||
@ -240,7 +240,7 @@ ssize_t pxml_parse(int *stateContext, const void *xmlbuf, size_t size,
|
||||
else if (C == CDASH)
|
||||
{
|
||||
/* Maintain current state, still waiting for '>'
|
||||
*/
|
||||
*/
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -473,17 +473,17 @@ static int pdu_make_ulp_pos_init(supl_ctx_t *ctx, supl_ulp_t *pdu)
|
||||
(void)asn_long2INTEGER(&ulp->message.choice.msSUPLPOSINIT.sETCapabilities.prefMethod, PrefMethod_agpsSETBasedPreferred);
|
||||
ulp->message.choice.msSUPLPOSINIT.sETCapabilities.posProtocol.rrlp = 1;
|
||||
|
||||
//GNSS-SDR mod
|
||||
// Use ctx->p.request to switch between a pre-defined set of assistance data request
|
||||
// reason: Some SUPL servers do not respond to Acquisition assistance depending on the status of other assistance flags
|
||||
// GNSS-SDR mod
|
||||
// Use ctx->p.request to switch between a pre-defined set of assistance data request
|
||||
// reason: Some SUPL servers do not respond to Acquisition assistance depending on the status of other assistance flags
|
||||
|
||||
switch (ctx->p.request)
|
||||
{
|
||||
case 0: //request almanac, time, and cell positions
|
||||
case 0: // request almanac, time, and cell positions
|
||||
req_adata->acquisitionAssistanceRequested = 0; // 1
|
||||
req_adata->navigationModelRequested = 0; // 1
|
||||
req_adata->referenceTimeRequested = 1;
|
||||
req_adata->utcModelRequested = 1; //1
|
||||
req_adata->utcModelRequested = 1; // 1
|
||||
req_adata->ionosphericModelRequested = 1; // 1
|
||||
req_adata->referenceLocationRequested = 1;
|
||||
req_adata->almanacRequested = 1;
|
||||
@ -493,17 +493,17 @@ static int pdu_make_ulp_pos_init(supl_ctx_t *ctx, supl_ulp_t *pdu)
|
||||
req_adata->acquisitionAssistanceRequested = 0; // 1
|
||||
req_adata->navigationModelRequested = 1; // 1
|
||||
req_adata->referenceTimeRequested = 1;
|
||||
req_adata->utcModelRequested = 0; //1
|
||||
req_adata->utcModelRequested = 0; // 1
|
||||
req_adata->ionosphericModelRequested = 0; // 1
|
||||
req_adata->referenceLocationRequested = 0;
|
||||
req_adata->almanacRequested = 0;
|
||||
req_adata->realTimeIntegrityRequested = 0; // 1
|
||||
break;
|
||||
case 2: //request Acquisition assistance (Doppler assistance)
|
||||
case 2: // request Acquisition assistance (Doppler assistance)
|
||||
req_adata->acquisitionAssistanceRequested = 1; // 1
|
||||
req_adata->navigationModelRequested = 0; // 1
|
||||
req_adata->referenceTimeRequested = 1;
|
||||
req_adata->utcModelRequested = 1; //1
|
||||
req_adata->utcModelRequested = 1; // 1
|
||||
req_adata->ionosphericModelRequested = 1; // 1
|
||||
req_adata->referenceLocationRequested = 1;
|
||||
req_adata->almanacRequested = 1;
|
||||
@ -513,7 +513,7 @@ static int pdu_make_ulp_pos_init(supl_ctx_t *ctx, supl_ulp_t *pdu)
|
||||
req_adata->acquisitionAssistanceRequested = 0; // 1
|
||||
req_adata->navigationModelRequested = 0; // 1
|
||||
req_adata->referenceTimeRequested = 1;
|
||||
req_adata->utcModelRequested = 1; //1
|
||||
req_adata->utcModelRequested = 1; // 1
|
||||
req_adata->ionosphericModelRequested = 1; // 1
|
||||
req_adata->referenceLocationRequested = 1;
|
||||
req_adata->almanacRequested = 1;
|
||||
@ -858,7 +858,7 @@ int EXPORT supl_collect_rrlp(supl_assist_t *assist, PDU_t *rrlp, struct timeval
|
||||
assist->iono.a0 = hdr->ionosphericModel->alfa0;
|
||||
assist->iono.a1 = hdr->ionosphericModel->alfa1;
|
||||
assist->iono.a2 = hdr->ionosphericModel->alfa2;
|
||||
assist->iono.a3 = hdr->ionosphericModel->alfa3; //missed in original supl client
|
||||
assist->iono.a3 = hdr->ionosphericModel->alfa3; // missed in original supl client
|
||||
assist->iono.b0 = hdr->ionosphericModel->beta0;
|
||||
assist->iono.b1 = hdr->ionosphericModel->beta1;
|
||||
assist->iono.b2 = hdr->ionosphericModel->beta2;
|
||||
@ -924,8 +924,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
memcpy(ctx->p.msisdn, "\xFF\xFF\x91\x94\x48\x45\x83\x98", 8);
|
||||
|
||||
/*
|
||||
** connect to server
|
||||
*/
|
||||
** connect to server
|
||||
*/
|
||||
|
||||
if (supl_server_connect(ctx, server) < 0)
|
||||
{
|
||||
@ -933,8 +933,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
}
|
||||
|
||||
/*
|
||||
** send SUPL_START
|
||||
*/
|
||||
** send SUPL_START
|
||||
*/
|
||||
|
||||
if (pdu_make_ulp_start(ctx, &ulp) < 0)
|
||||
{
|
||||
@ -945,8 +945,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
supl_ulp_free(&ulp);
|
||||
|
||||
/*
|
||||
** should receive SUPL_RESPONSE back
|
||||
*/
|
||||
** should receive SUPL_RESPONSE back
|
||||
*/
|
||||
|
||||
if (supl_ulp_recv(ctx, &ulp) < 0)
|
||||
{
|
||||
@ -965,8 +965,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
supl_ulp_free(&ulp);
|
||||
|
||||
/*
|
||||
** send SUPL_POS_INIT
|
||||
*/
|
||||
** send SUPL_POS_INIT
|
||||
*/
|
||||
|
||||
if (pdu_make_ulp_pos_init(ctx, &ulp) < 0)
|
||||
{
|
||||
@ -976,8 +976,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
(void)supl_ulp_send(ctx, &ulp);
|
||||
|
||||
/*
|
||||
** should get SUPLPOS back - bounce back and forth until all messages have arrived
|
||||
*/
|
||||
** should get SUPLPOS back - bounce back and forth until all messages have arrived
|
||||
*/
|
||||
|
||||
memset(assist, 0, sizeof(supl_assist_t));
|
||||
|
||||
@ -1047,8 +1047,8 @@ int EXPORT supl_get_assist(supl_ctx_t *ctx, char *server, supl_assist_t *assist)
|
||||
supl_ulp_free(&ulp);
|
||||
|
||||
/*
|
||||
** send SUPL_END (but who really cares)
|
||||
*/
|
||||
** send SUPL_END (but who really cares)
|
||||
*/
|
||||
|
||||
supl_close(ctx);
|
||||
|
||||
|
@ -55,9 +55,9 @@ using namespace google;
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Concurrent queues that communicates the Telemetry Decoder
|
||||
* to the Observables modules
|
||||
*/
|
||||
* Concurrent queues that communicates the Telemetry Decoder
|
||||
* to the Observables modules
|
||||
*/
|
||||
|
||||
// For GPS NAVIGATION (L1)
|
||||
Concurrent_Queue<Gps_Acq_Assist> global_gps_acq_assist_queue;
|
||||
|
Loading…
Reference in New Issue
Block a user