1
0
mirror of https://github.com/gnss-sdr/gnss-sdr synced 2025-01-18 21:23:02 +00:00
This commit is contained in:
Carles Fernandez 2019-10-11 19:30:33 +02:00
commit e2fad71f52
No known key found for this signature in database
GPG Key ID: 4C583C52B0C3877D
160 changed files with 4777 additions and 1492 deletions

View File

@ -99,6 +99,7 @@ Checks: '-*,
performance-unnecessary-copy-initialization,
performance-unnecessary-value-param,
readability-avoid-const-params-in-decls,
readability-braces-around-statements,
readability-container-size-empty,
readability-identifier-naming,
readability-inconsistent-declaration-parameter-name,
@ -194,8 +195,6 @@ CheckOptions:
value: CamelCase
- key: modernize-pass-by-value.IncludeStyle
value: llvm
- key: modernize-pass-by-value.ValuesOnly
value: '0'
- key: modernize-raw-string-literal.ReplaceShorterLiterals
value: '0'
- key: modernize-replace-auto-ptr.IncludeStyle
@ -248,6 +247,8 @@ CheckOptions:
value: ''
- key: performance-unnecessary-value-param.IncludeStyle
value: llvm
- key: readability-braces-around-statements.ShortStatementLines
value: '0'
- key: readability-identifier-naming.AbstractClassCase
value: CamelCase
- key: readability-identifier-naming.AbstractClassPrefix

View File

@ -3661,28 +3661,28 @@ uint32_t Rtcm::msm_lock_time_indicator(uint32_t lock_time_period_s)
uint32_t Rtcm::msm_extended_lock_time_indicator(uint32_t lock_time_period_s)
{
// Table 3.5-75
if( lock_time_period_s < 64 ) return ( lock_time_period_s );
if( 64 <= lock_time_period_s && lock_time_period_s < 128 ) return ( 64 + (lock_time_period_s - 64 ) / 2 );
if( 128 <= lock_time_period_s && lock_time_period_s < 256 ) return ( 96 + (lock_time_period_s - 128 ) / 4 );
if( 256 <= lock_time_period_s && lock_time_period_s < 512 ) return (128 + (lock_time_period_s - 256 ) / 8 );
if( 512 <= lock_time_period_s && lock_time_period_s < 1024 ) return (160 + (lock_time_period_s - 512 ) / 16 );
if( 1024 <= lock_time_period_s && lock_time_period_s < 2048 ) return (192 + (lock_time_period_s - 1024 ) / 32 );
if( 2048 <= lock_time_period_s && lock_time_period_s < 4096 ) return (224 + (lock_time_period_s - 2048 ) / 64 );
if( 4096 <= lock_time_period_s && lock_time_period_s < 8192 ) return (256 + (lock_time_period_s - 4096 ) / 128 );
if( 8192 <= lock_time_period_s && lock_time_period_s < 16384 ) return (288 + (lock_time_period_s - 8192 ) / 256 );
if( 16384 <= lock_time_period_s && lock_time_period_s < 32768 ) return (320 + (lock_time_period_s - 16384 ) / 512 );
if( 32768 <= lock_time_period_s && lock_time_period_s < 65536 ) return (352 + (lock_time_period_s - 32768 ) / 1024 );
if( 65536 <= lock_time_period_s && lock_time_period_s < 131072 ) return (384 + (lock_time_period_s - 65536 ) / 2048 );
if( 131072 <= lock_time_period_s && lock_time_period_s < 262144 ) return (416 + (lock_time_period_s - 131072 ) / 4096 );
if( 262144 <= lock_time_period_s && lock_time_period_s < 524288 ) return (448 + (lock_time_period_s - 262144 ) / 8192 );
if( 524288 <= lock_time_period_s && lock_time_period_s < 1048576 ) return (480 + (lock_time_period_s - 524288 ) / 16384 );
if( 1048576 <= lock_time_period_s && lock_time_period_s < 2097152 ) return (512 + (lock_time_period_s - 1048576 ) / 32768 );
if( 2097152 <= lock_time_period_s && lock_time_period_s < 4194304 ) return (544 + (lock_time_period_s - 2097152 ) / 65536 );
if( 4194304 <= lock_time_period_s && lock_time_period_s < 8388608 ) return (576 + (lock_time_period_s - 4194304 ) / 131072 );
if( 8388608 <= lock_time_period_s && lock_time_period_s < 16777216 ) return (608 + (lock_time_period_s - 8388608 ) / 262144 );
if( 16777216 <= lock_time_period_s && lock_time_period_s < 33554432 ) return (640 + (lock_time_period_s - 16777216) / 524288 );
if( 33554432 <= lock_time_period_s && lock_time_period_s < 67108864 ) return (672 + (lock_time_period_s - 33554432) / 1048576);
if( 67108864 <= lock_time_period_s ) return (704 );
if( lock_time_period_s < 64 ) return ( lock_time_period_s ); // NOLINT
if( 64 <= lock_time_period_s && lock_time_period_s < 128 ) return ( 64 + (lock_time_period_s - 64 ) / 2 ); // NOLINT
if( 128 <= lock_time_period_s && lock_time_period_s < 256 ) return ( 96 + (lock_time_period_s - 128 ) / 4 ); // NOLINT
if( 256 <= lock_time_period_s && lock_time_period_s < 512 ) return (128 + (lock_time_period_s - 256 ) / 8 ); // NOLINT
if( 512 <= lock_time_period_s && lock_time_period_s < 1024 ) return (160 + (lock_time_period_s - 512 ) / 16 ); // NOLINT
if( 1024 <= lock_time_period_s && lock_time_period_s < 2048 ) return (192 + (lock_time_period_s - 1024 ) / 32 ); // NOLINT
if( 2048 <= lock_time_period_s && lock_time_period_s < 4096 ) return (224 + (lock_time_period_s - 2048 ) / 64 ); // NOLINT
if( 4096 <= lock_time_period_s && lock_time_period_s < 8192 ) return (256 + (lock_time_period_s - 4096 ) / 128 ); // NOLINT
if( 8192 <= lock_time_period_s && lock_time_period_s < 16384 ) return (288 + (lock_time_period_s - 8192 ) / 256 ); // NOLINT
if( 16384 <= lock_time_period_s && lock_time_period_s < 32768 ) return (320 + (lock_time_period_s - 16384 ) / 512 ); // NOLINT
if( 32768 <= lock_time_period_s && lock_time_period_s < 65536 ) return (352 + (lock_time_period_s - 32768 ) / 1024 ); // NOLINT
if( 65536 <= lock_time_period_s && lock_time_period_s < 131072 ) return (384 + (lock_time_period_s - 65536 ) / 2048 ); // NOLINT
if( 131072 <= lock_time_period_s && lock_time_period_s < 262144 ) return (416 + (lock_time_period_s - 131072 ) / 4096 ); // NOLINT
if( 262144 <= lock_time_period_s && lock_time_period_s < 524288 ) return (448 + (lock_time_period_s - 262144 ) / 8192 ); // NOLINT
if( 524288 <= lock_time_period_s && lock_time_period_s < 1048576 ) return (480 + (lock_time_period_s - 524288 ) / 16384 ); // NOLINT
if( 1048576 <= lock_time_period_s && lock_time_period_s < 2097152 ) return (512 + (lock_time_period_s - 1048576 ) / 32768 ); // NOLINT
if( 2097152 <= lock_time_period_s && lock_time_period_s < 4194304 ) return (544 + (lock_time_period_s - 2097152 ) / 65536 ); // NOLINT
if( 4194304 <= lock_time_period_s && lock_time_period_s < 8388608 ) return (576 + (lock_time_period_s - 4194304 ) / 131072 ); // NOLINT
if( 8388608 <= lock_time_period_s && lock_time_period_s < 16777216 ) return (608 + (lock_time_period_s - 8388608 ) / 262144 ); // NOLINT
if( 16777216 <= lock_time_period_s && lock_time_period_s < 33554432 ) return (640 + (lock_time_period_s - 16777216) / 524288 ); // NOLINT
if( 33554432 <= lock_time_period_s && lock_time_period_s < 67108864 ) return (672 + (lock_time_period_s - 33554432) / 1048576); // NOLINT
if( 67108864 <= lock_time_period_s ) return (704 ); // NOLINT
return 1023; // will never happen
}
// clang-format on

View File

@ -72,7 +72,10 @@ GalileoE1PcpsAmbiguousAcquisitionFpga::GalileoE1PcpsAmbiguousAcquisitionFpga(
acq_parameters.fs_in = fs_in;
doppler_max_ = configuration_->property(role + ".doppler_max", 5000);
if (FLAGS_doppler_max != 0) doppler_max_ = FLAGS_doppler_max;
if (FLAGS_doppler_max != 0)
{
doppler_max_ = FLAGS_doppler_max;
}
acq_parameters.doppler_max = doppler_max_;
acquire_pilot_ = configuration_->property(role + ".acquire_pilot", false); // could be true in future versions

View File

@ -69,7 +69,10 @@ GalileoE5aPcpsAcquisitionFpga::GalileoE5aPcpsAcquisitionFpga(ConfigurationInterf
acq_parameters.fs_in = fs_in;
doppler_max_ = configuration_->property(role + ".doppler_max", 5000);
if (FLAGS_doppler_max != 0) doppler_max_ = FLAGS_doppler_max;
if (FLAGS_doppler_max != 0)
{
doppler_max_ = FLAGS_doppler_max;
}
acq_parameters.doppler_max = doppler_max_;
acq_pilot_ = configuration_->property(role + ".acquire_pilot", false);

View File

@ -71,7 +71,10 @@ GpsL1CaPcpsAcquisitionFpga::GpsL1CaPcpsAcquisitionFpga(
acq_parameters.fs_in = fs_in;
doppler_max_ = configuration_->property(role + ".doppler_max", 5000);
if (FLAGS_doppler_max != 0) doppler_max_ = FLAGS_doppler_max;
if (FLAGS_doppler_max != 0)
{
doppler_max_ = FLAGS_doppler_max;
}
acq_parameters.doppler_max = doppler_max_;
auto code_length = static_cast<uint32_t>(std::round(static_cast<double>(fs_in) / (GPS_L1_CA_CODE_RATE_CPS / GPS_L1_CA_CODE_LENGTH_CHIPS)));
acq_parameters.code_length = code_length;

View File

@ -68,7 +68,10 @@ GpsL2MPcpsAcquisitionFpga::GpsL2MPcpsAcquisitionFpga(
DLOG(INFO) << role << " satellite repeat = " << acq_parameters.repeat_satellite;
doppler_max_ = configuration->property(role + ".doppler_max", 5000);
if (FLAGS_doppler_max != 0) doppler_max_ = FLAGS_doppler_max;
if (FLAGS_doppler_max != 0)
{
doppler_max_ = FLAGS_doppler_max;
}
acq_parameters.doppler_max = doppler_max_;
unsigned int code_length = std::round(static_cast<double>(fs_in_) / (GPS_L2_M_CODE_RATE_CPS / static_cast<double>(GPS_L2_M_CODE_LENGTH_CHIPS)));

View File

@ -73,7 +73,10 @@ GpsL5iPcpsAcquisitionFpga::GpsL5iPcpsAcquisitionFpga(
acq_parameters.fs_in = fs_in;
doppler_max_ = configuration->property(role + ".doppler_max", 5000);
if (FLAGS_doppler_max != 0) doppler_max_ = FLAGS_doppler_max;
if (FLAGS_doppler_max != 0)
{
doppler_max_ = FLAGS_doppler_max;
}
acq_parameters.doppler_max = doppler_max_;
// -- Find number of samples per spreading code -------------------------

View File

@ -68,10 +68,16 @@ GpsL2MDllPllTrackingFpga::GpsL2MDllPllTrackingFpga(
bool dump_mat = configuration->property(role + ".dump_mat", true);
trk_param_fpga.dump_mat = dump_mat;
float pll_bw_hz = configuration->property(role + ".pll_bw_hz", 2.0);
if (FLAGS_pll_bw_hz != 0.0) pll_bw_hz = static_cast<float>(FLAGS_pll_bw_hz);
if (FLAGS_pll_bw_hz != 0.0)
{
pll_bw_hz = static_cast<float>(FLAGS_pll_bw_hz);
}
trk_param_fpga.pll_bw_hz = pll_bw_hz;
float dll_bw_hz = configuration->property(role + ".dll_bw_hz", 0.75);
if (FLAGS_dll_bw_hz != 0.0) dll_bw_hz = static_cast<float>(FLAGS_dll_bw_hz);
if (FLAGS_dll_bw_hz != 0.0)
{
dll_bw_hz = static_cast<float>(FLAGS_dll_bw_hz);
}
trk_param_fpga.dll_bw_hz = dll_bw_hz;
float early_late_space_chips = configuration->property(role + ".early_late_space_chips", 0.5);
trk_param_fpga.early_late_space_chips = early_late_space_chips;

View File

@ -1513,7 +1513,10 @@ int dll_pll_veml_tracking_fpga::general_work(int noutput_items __attribute__((un
{
d_worker_is_done = false;
boost::mutex::scoped_lock lock(d_mutex);
while (!d_worker_is_done) m_condition.wait(lock);
while (!d_worker_is_done)
{
m_condition.wait(lock);
}
// Signal alignment (skip samples until the incoming signal is aligned with local replica)
int64_t acq_trk_diff_samples;

View File

@ -48,7 +48,9 @@ static void Accuracy_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void AlertFlag_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void AntiSpoofFlag_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void BCCHCarrier_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -80,7 +80,10 @@ asn_enc_rval_t BIT_STRING_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
uint8_t *buf;
uint8_t *end;
if (!st || !st->buf) _ASN_ENCODE_FAILED;
if (!st || !st->buf)
{
_ASN_ENCODE_FAILED;
}
er.encoded = 0;
@ -99,14 +102,20 @@ asn_enc_rval_t BIT_STRING_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
er.encoded += p - scratch;
_ASN_CALLBACK(scratch, p - scratch);
p = scratch;
if (nline) _i_ASN_TEXT_INDENT(1, ilevel);
if (nline)
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
}
memcpy(p + 0, _bit_pattern[v >> 4], 4);
memcpy(p + 4, _bit_pattern[v & 0x0f], 4);
p += 8;
}
if (!xcan && ((buf - st->buf) % 8) == 0) _i_ASN_TEXT_INDENT(1, ilevel);
if (!xcan && ((buf - st->buf) % 8) == 0)
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
er.encoded += p - scratch;
_ASN_CALLBACK(scratch, p - scratch);
p = scratch;
@ -116,12 +125,18 @@ asn_enc_rval_t BIT_STRING_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
int v = *buf;
int ubits = st->bits_unused;
int i;
for (i = 7; i >= ubits; i--) *p++ = (v & (1 << i)) ? 0x31 : 0x30;
for (i = 7; i >= ubits; i--)
{
*p++ = (v & (1 << i)) ? 0x31 : 0x30;
}
er.encoded += p - scratch;
_ASN_CALLBACK(scratch, p - scratch);
}
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
_ASN_ENCODED_OK(er);
cb_failed:
@ -143,7 +158,10 @@ int BIT_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
(void)td; /* Unused argument */
if (!st || !st->buf) return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
if (!st || !st->buf)
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
ilevel++;
buf = st->buf;
@ -158,7 +176,10 @@ int BIT_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
{
_i_INDENT(1);
/* Dump the string */
if (cb(scratch, p - scratch, app_key) < 0) return -1;
if (cb(scratch, p - scratch, app_key) < 0)
{
return -1;
}
p = scratch;
}
*p++ = h2c[*buf >> 4];
@ -176,7 +197,10 @@ int BIT_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
}
/* Dump the incomplete 16-bytes row */
if (cb(scratch, p - scratch, app_key) < 0) return -1;
if (cb(scratch, p - scratch, app_key) < 0)
{
return -1;
}
}
return 0;

View File

@ -65,7 +65,10 @@ asn_dec_rval_t BOOLEAN_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
*/
rval = ber_check_tags(opt_codec_ctx, td, 0, buf_ptr, size, tag_mode, 0,
&length, 0);
if (rval.code != RC_OK) return rval;
if (rval.code != RC_OK)
{
return rval;
}
ASN_DEBUG("Boolean length is %d bytes", (int)length);
@ -159,7 +162,9 @@ static enum xer_pbd_rval BOOLEAN__xer_body_decode(asn_TYPE_descriptor_t *td,
case XCT_UNKNOWN_BO:
if (xer_check_tag(chunk_buf, chunk_size, "true") !=
XCT_BOTH)
{
return XPBD_BROKEN_ENCODING;
}
/* "<true/>" */
*st = 1; /* Or 0xff as in DER?.. */
break;
@ -171,11 +176,15 @@ static enum xer_pbd_rval BOOLEAN__xer_body_decode(asn_TYPE_descriptor_t *td,
else
{
if (xer_is_whitespace(chunk_buf, chunk_size))
{
return XPBD_NOT_BODY_IGNORE;
}
else
{
return XPBD_BROKEN_ENCODING;
}
}
}
asn_dec_rval_t BOOLEAN_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td, void **sptr,
@ -197,7 +206,10 @@ asn_enc_rval_t BOOLEAN_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
(void)ilevel;
(void)flags;
if (!st) _ASN_ENCODE_FAILED;
if (!st)
{
_ASN_ENCODE_FAILED;
}
if (*st)
{
@ -269,7 +281,10 @@ asn_dec_rval_t BOOLEAN_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = (BOOLEAN_t *)(*sptr = MALLOC(sizeof(*st)));
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
/*
@ -304,7 +319,10 @@ asn_enc_rval_t BOOLEAN_encode_uper(asn_TYPE_descriptor_t *td,
(void)constraints;
if (!st) _ASN_ENCODE_FAILED;
if (!st)
{
_ASN_ENCODE_FAILED;
}
per_put_few_bits(po, *st ? 1 : 0, 1);

View File

@ -48,7 +48,9 @@ static void BSIC_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -50,8 +50,10 @@ static void BTSPosition_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_Ext_GeographicalInformation.uper_decoder;
td->uper_encoder = asn_DEF_Ext_GeographicalInformation.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints =
asn_DEF_Ext_GeographicalInformation.per_constraints;
}
td->elements = asn_DEF_Ext_GeographicalInformation.elements;
td->elements_count = asn_DEF_Ext_GeographicalInformation.elements_count;
td->specifics = asn_DEF_Ext_GeographicalInformation.specifics;

View File

@ -48,7 +48,9 @@ static void BitNumber_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void CellID_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,13 +49,21 @@ asn_dec_rval_t ENUMERATED_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = (ENUMERATED_t *)(*sptr = CALLOC(1, sizeof(*st)));
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
rval =
NativeEnumerated_decode_uper(opt_codec_ctx, td, constraints, &vptr, pd);
if (rval.code == RC_OK)
if (asn_long2INTEGER(st, value)) rval.code = RC_FAIL;
{
if (asn_long2INTEGER(st, value))
{
rval.code = RC_FAIL;
}
}
return rval;
}
@ -66,7 +74,10 @@ asn_enc_rval_t ENUMERATED_encode_uper(asn_TYPE_descriptor_t *td,
ENUMERATED_t *st = (ENUMERATED_t *)sptr;
int64_t value;
if (asn_INTEGER2long(st, &value)) _ASN_ENCODE_FAILED;
if (asn_INTEGER2long(st, &value))
{
_ASN_ENCODE_FAILED;
}
return NativeEnumerated_encode_uper(td, constraints, &value, po);
}

View File

@ -31,7 +31,9 @@ static void EnvironmentCharacter_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -29,7 +29,9 @@ static void ErrorCodes_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -50,7 +50,9 @@ static void ExpOTDUncertainty_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void ExpectedOTD_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -51,7 +51,9 @@ static void Ext_GeographicalInformation_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_OCTET_STRING.uper_decoder;
td->uper_encoder = asn_DEF_OCTET_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_OCTET_STRING.per_constraints;
}
td->elements = asn_DEF_OCTET_STRING.elements;
td->elements_count = asn_DEF_OCTET_STRING.elements_count;
td->specifics = asn_DEF_OCTET_STRING.specifics;

View File

@ -31,7 +31,9 @@ static void ExtensionContainer_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_INTEGER.uper_decoder;
td->uper_encoder = asn_DEF_INTEGER.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_INTEGER.per_constraints;
}
td->elements = asn_DEF_INTEGER.elements;
td->elements_count = asn_DEF_INTEGER.elements_count;
td->specifics = asn_DEF_INTEGER.specifics;

View File

@ -48,7 +48,9 @@ static void FineRTD_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void FixType_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void FrameDrift_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void FrameNumber_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -51,7 +51,9 @@ static void GANSSAssistanceData_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_OCTET_STRING.uper_decoder;
td->uper_encoder = asn_DEF_OCTET_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_OCTET_STRING.per_constraints;
}
td->elements = asn_DEF_OCTET_STRING.elements;
td->elements_count = asn_DEF_OCTET_STRING.elements_count;
td->specifics = asn_DEF_OCTET_STRING.specifics;

View File

@ -49,7 +49,9 @@ static void GANSSDataBit_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -60,7 +60,9 @@ static void GANSSPositioningMethod_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_BIT_STRING.uper_decoder;
td->uper_encoder = asn_DEF_BIT_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_BIT_STRING.per_constraints;
}
td->elements = asn_DEF_BIT_STRING.elements;
td->elements_count = asn_DEF_BIT_STRING.elements_count;
td->specifics = asn_DEF_BIT_STRING.specifics;

View File

@ -49,7 +49,9 @@ static void GANSSSignalID_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void GANSSTOD_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -50,7 +50,9 @@ static void GANSSTODUncertainty_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void GANSSTODm_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -51,7 +51,9 @@ static void GPSAssistanceData_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_OCTET_STRING.uper_decoder;
td->uper_encoder = asn_DEF_OCTET_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_OCTET_STRING.per_constraints;
}
td->elements = asn_DEF_OCTET_STRING.elements;
td->elements_count = asn_DEF_OCTET_STRING.elements_count;
td->specifics = asn_DEF_OCTET_STRING.specifics;

View File

@ -50,7 +50,9 @@ static void GPSReferenceTimeUncertainty_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void GPSTOW23b_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void GPSTOW24b_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void GPSWeek_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -72,10 +72,16 @@ asn_enc_rval_t INTEGER_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
switch (*buf)
{
case 0x00:
if ((buf[1] & 0x80) == 0) continue;
if ((buf[1] & 0x80) == 0)
{
continue;
}
break;
case 0xff:
if ((buf[1] & 0x80)) continue;
if ((buf[1] & 0x80))
{
continue;
}
break;
}
break;
@ -91,7 +97,10 @@ asn_enc_rval_t INTEGER_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
st->size -= shift; /* New size, minus bad bytes */
end = nb + st->size;
for (; nb < end; nb++, buf++) *nb = *buf;
for (; nb < end; nb++, buf++)
{
*nb = *buf;
}
}
} /* if(1) */
@ -130,10 +139,16 @@ static ssize_t INTEGER__dump(asn_TYPE_descriptor_t *td, const INTEGER_t *st,
switch (*buf)
{
case 0x00:
if ((buf[1] & 0x80) == 0) continue;
if ((buf[1] & 0x80) == 0)
{
continue;
}
break;
case 0xff:
if ((buf[1] & 0x80) != 0) continue;
if ((buf[1] & 0x80) != 0)
{
continue;
}
break;
}
break;
@ -153,7 +168,10 @@ static ssize_t INTEGER__dump(asn_TYPE_descriptor_t *td, const INTEGER_t *st,
else
{
accum = (*buf & 0x80) ? -1LL : 0LL;
for (; buf < buf_end; buf++) accum = (accum * 256) | *buf;
for (; buf < buf_end; buf++)
{
accum = (accum * 256) | *buf;
}
}
el = INTEGER_map_value2enum(specs, accum);
@ -162,11 +180,15 @@ static ssize_t INTEGER__dump(asn_TYPE_descriptor_t *td, const INTEGER_t *st,
scrsize = el->enum_len + 32;
scr = (char *)alloca(scrsize);
if (plainOrXER == 0)
{
ret = snprintf(scr, scrsize, "%+" PRId64 "(%s)", accum,
el->enum_name);
}
else
{
ret = snprintf(scr, scrsize, "<%s/>", el->enum_name);
}
}
else if (plainOrXER && specs && specs->strict_enumeration)
{
ASN_DEBUG(
@ -209,7 +231,10 @@ static ssize_t INTEGER__dump(asn_TYPE_descriptor_t *td, const INTEGER_t *st,
if ((p - scratch) >= (ssize_t)(sizeof(scratch) - 4))
{
/* Flush buffer */
if (cb(scratch, p - scratch, app_key) < 0) return -1;
if (cb(scratch, p - scratch, app_key) < 0)
{
return -1;
}
wrote += p - scratch;
p = scratch;
}
@ -217,7 +242,10 @@ static ssize_t INTEGER__dump(asn_TYPE_descriptor_t *td, const INTEGER_t *st,
*p++ = h2c[*buf & 0x0F];
*p++ = 0x3a; /* ":" */
}
if (p != scratch) p--; /* Remove the last ":" */
if (p != scratch)
{
p--; /* Remove the last ":" */
}
wrote += p - scratch;
return (cb(scratch, p - scratch, app_key) < 0) ? -1 : wrote;
@ -236,9 +264,13 @@ int INTEGER_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
(void)ilevel;
if (!st || !st->buf)
{
ret = cb("<absent>", 8, app_key);
}
else
{
ret = INTEGER__dump(td, st, cb, app_key, 0);
}
return (ret < 0) ? -1 : 0;
}
@ -266,9 +298,11 @@ static int INTEGER__compar_enum2value(const void *kp, const void *am)
ptr++, name++)
{
if (*ptr != *name)
{
return *(const unsigned char *)ptr -
*(const unsigned char *)name;
}
}
return name[0] ? -1 : 0;
}
@ -280,7 +314,10 @@ static const asn_INTEGER_enum_map_t *INTEGER_map_enum2value(
struct e2v_key key;
const char *lp;
if (!count) return NULL;
if (!count)
{
return NULL;
}
/* Guaranteed: assert(lstart < lstop); */
/* Figure out the tag name */
@ -302,7 +339,10 @@ static const asn_INTEGER_enum_map_t *INTEGER_map_enum2value(
}
break;
}
if (lp == lstop) return NULL; /* No tag found */
if (lp == lstop)
{
return NULL; /* No tag found */
}
lstop = lp;
key.start = lstart;
@ -326,18 +366,27 @@ static int INTEGER__compar_value2enum(const void *kp, const void *am)
const asn_INTEGER_enum_map_t *el = (const asn_INTEGER_enum_map_t *)am;
int64_t b = el->nat_value;
if (a < b)
{
return -1;
}
else if (a == b)
{
return 0;
}
else
{
return 1;
}
}
const asn_INTEGER_enum_map_t *INTEGER_map_value2enum(
asn_INTEGER_specifics_t *specs, int64_t value)
{
int count = specs ? specs->map_count : 0;
if (!count) return 0;
if (!count)
{
return 0;
}
return (asn_INTEGER_enum_map_t *)bsearch(&value, specs->value2enum, count,
sizeof(specs->value2enum[0]),
INTEGER__compar_value2enum);
@ -387,8 +436,10 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
} state = ST_SKIPSPACE;
if (chunk_size)
{
ASN_DEBUG("INTEGER body %ld 0x%2x..0x%2x", (int64_t)chunk_size, *lstart,
lstop[-1]);
}
/*
* We may have received a tag here. It will be processed inline.
@ -468,8 +519,10 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
{
int64_t new_value = value * 10;
if (new_value / 10 != value) /* Overflow */
if (new_value / 10 != value)
{ /* Overflow */
return XPBD_DECODER_LIMIT;
}
value = new_value + (lv - 0x30);
/* Check for two's complement overflow */
@ -524,7 +577,9 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
ASN_DEBUG("INTEGER re-evaluate as hex form");
if (INTEGER_st_prealloc(st,
(chunk_size / 3) + 1))
{
return XPBD_SYSTEM_FAILURE;
}
state = ST_SKIPSPHEX;
lp = lstart - 1;
continue;
@ -568,7 +623,9 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
"INTEGER re-evaluate as hex form");
if (INTEGER_st_prealloc(
st, (chunk_size / 3) + 1))
{
return XPBD_SYSTEM_FAILURE;
}
state = ST_SKIPSPHEX;
lp = lstart - 1;
continue;
@ -599,7 +656,10 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
default:
if (xer_is_whitespace(lp, lstop - lp))
{
if (state != ST_EXTRASTUFF) return XPBD_NOT_BODY_IGNORE;
if (state != ST_EXTRASTUFF)
{
return XPBD_NOT_BODY_IGNORE;
}
break;
}
else
@ -613,7 +673,10 @@ static enum xer_pbd_rval INTEGER__xer_body_decode(asn_TYPE_descriptor_t *td,
value *= sign; /* Change sign, if needed */
if (asn_long2INTEGER(st, value)) return XPBD_SYSTEM_FAILURE;
if (asn_long2INTEGER(st, value))
{
return XPBD_SYSTEM_FAILURE;
}
return XPBD_BODY_CONSUMED;
}
@ -638,10 +701,16 @@ asn_enc_rval_t INTEGER_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
(void)ilevel;
(void)flags;
if (!st || !st->buf) _ASN_ENCODE_FAILED;
if (!st || !st->buf)
{
_ASN_ENCODE_FAILED;
}
er.encoded = INTEGER__dump(td, st, cb, app_key, 1);
if (er.encoded < 0) _ASN_ENCODE_FAILED;
if (er.encoded < 0)
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
@ -662,17 +731,29 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = (INTEGER_t *)(*sptr = CALLOC(1, sizeof(*st)));
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
if (!constraints) constraints = td->per_constraints;
if (!constraints)
{
constraints = td->per_constraints;
}
ct = constraints ? &constraints->value : 0;
if (ct && ct->flags & APC_EXTENSIBLE)
{
int inext = per_get_few_bits(pd, 1);
if (inext < 0) _ASN_DECODE_STARVED;
if (inext) ct = 0;
if (inext < 0)
{
_ASN_DECODE_STARVED;
}
if (inext)
{
ct = 0;
}
}
FREEMEM(st->buf);
@ -683,14 +764,20 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (ct->flags & APC_SEMI_CONSTRAINED)
{
st->buf = (uint8_t *)CALLOC(1, 2);
if (!st->buf) _ASN_DECODE_FAILED;
if (!st->buf)
{
_ASN_DECODE_FAILED;
}
st->size = 1;
}
else if (ct->flags & APC_CONSTRAINED && ct->range_bits >= 0)
{
size_t size = (ct->range_bits + 7) >> 3;
st->buf = (uint8_t *)MALLOC(1 + size + 1);
if (!st->buf) _ASN_DECODE_FAILED;
if (!st->buf)
{
_ASN_DECODE_FAILED;
}
st->size = size;
}
}
@ -707,15 +794,24 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
{
int64_t lhalf;
value = per_get_few_bits(pd, 16);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
lhalf = per_get_few_bits(pd, 16);
if (lhalf < 0) _ASN_DECODE_STARVED;
if (lhalf < 0)
{
_ASN_DECODE_STARVED;
}
value = (value << 16) | lhalf;
}
else
{
value = per_get_few_bits(pd, ct->range_bits);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
}
ASN_DEBUG("Got value %ld + low %ld", value,
ct->lower_bound);
@ -723,7 +819,9 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if ((specs && specs->field_unsigned)
? asn_ulong2INTEGER(st, value)
: asn_long2INTEGER(st, value))
{
_ASN_DECODE_FAILED;
}
return rval;
}
}
@ -741,14 +839,23 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
/* Get the PER length */
len = uper_get_length(pd, -1, &repeat);
if (len < 0) _ASN_DECODE_STARVED;
if (len < 0)
{
_ASN_DECODE_STARVED;
}
p = REALLOC(st->buf, st->size + len + 1);
if (!p) _ASN_DECODE_FAILED;
if (!p)
{
_ASN_DECODE_FAILED;
}
st->buf = (uint8_t *)p;
ret = per_get_many_bits(pd, &st->buf[st->size], 0, 8 * len);
if (ret < 0) _ASN_DECODE_STARVED;
if (ret < 0)
{
_ASN_DECODE_STARVED;
}
st->size += len;
}
while (repeat);
@ -761,10 +868,15 @@ asn_dec_rval_t INTEGER_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
* TODO: replace by in-place arithmetics.
*/
int64_t value;
if (asn_INTEGER2long(st, &value)) _ASN_DECODE_FAILED;
if (asn_long2INTEGER(st, value + ct->lower_bound))
if (asn_INTEGER2long(st, &value))
{
_ASN_DECODE_FAILED;
}
if (asn_long2INTEGER(st, value + ct->lower_bound))
{
_ASN_DECODE_FAILED;
}
}
return rval;
}
@ -781,9 +893,15 @@ asn_enc_rval_t INTEGER_encode_uper(asn_TYPE_descriptor_t *td,
asn_per_constraint_t *ct;
int64_t value = 0;
if (!st || st->size == 0) _ASN_ENCODE_FAILED;
if (!st || st->size == 0)
{
_ASN_ENCODE_FAILED;
}
if (!constraints) constraints = td->per_constraints;
if (!constraints)
{
constraints = td->per_constraints;
}
ct = constraints ? &constraints->value : 0;
er.encoded = 0;
@ -794,18 +912,26 @@ asn_enc_rval_t INTEGER_encode_uper(asn_TYPE_descriptor_t *td,
if (specs && specs->field_unsigned)
{
uint64_t uval;
if (asn_INTEGER2ulong(st, &uval)) _ASN_ENCODE_FAILED;
if (asn_INTEGER2ulong(st, &uval))
{
_ASN_ENCODE_FAILED;
}
/* Check proper range */
if (ct->flags & APC_SEMI_CONSTRAINED)
{
if (uval < (uint64_t)ct->lower_bound) inext = 1;
if (uval < (uint64_t)ct->lower_bound)
{
inext = 1;
}
}
else if (ct->range_bits >= 0)
{
if (uval < (uint64_t)ct->lower_bound ||
uval > (uint64_t)ct->upper_bound)
{
inext = 1;
}
}
ASN_DEBUG("Value %lu (%02x/%d) lb %lu ub %lu %s", uval,
st->buf[0], st->size, ct->lower_bound,
ct->upper_bound, inext ? "ext" : "fix");
@ -813,26 +939,40 @@ asn_enc_rval_t INTEGER_encode_uper(asn_TYPE_descriptor_t *td,
}
else
{
if (asn_INTEGER2long(st, &value)) _ASN_ENCODE_FAILED;
if (asn_INTEGER2long(st, &value))
{
_ASN_ENCODE_FAILED;
}
/* Check proper range */
if (ct->flags & APC_SEMI_CONSTRAINED)
{
if (value < ct->lower_bound) inext = 1;
if (value < ct->lower_bound)
{
inext = 1;
}
}
else if (ct->range_bits >= 0)
{
if (value < ct->lower_bound ||
value > ct->upper_bound)
{
inext = 1;
}
}
ASN_DEBUG("Value %ld (%02x/%d) lb %ld ub %ld %s", value,
st->buf[0], st->size, ct->lower_bound,
ct->upper_bound, inext ? "ext" : "fix");
}
if (ct->flags & APC_EXTENSIBLE)
{
if (per_put_few_bits(po, inext, 1)) _ASN_ENCODE_FAILED;
if (inext) ct = 0;
if (per_put_few_bits(po, inext, 1))
{
_ASN_ENCODE_FAILED;
}
if (inext)
{
ct = 0;
}
}
else if (inext)
{
@ -851,14 +991,18 @@ asn_enc_rval_t INTEGER_encode_uper(asn_TYPE_descriptor_t *td,
int64_t v = value - ct->lower_bound;
if (per_put_few_bits(po, v >> 1, 31) ||
per_put_few_bits(po, v, 1))
{
_ASN_ENCODE_FAILED;
}
}
else
{
if (per_put_few_bits(po, value - ct->lower_bound,
ct->range_bits))
{
_ASN_ENCODE_FAILED;
}
}
_ASN_ENCODED_OK(er);
}
@ -872,8 +1016,14 @@ asn_enc_rval_t INTEGER_encode_uper(asn_TYPE_descriptor_t *td,
for (buf = st->buf, end = st->buf + st->size; buf < end;)
{
ssize_t mayEncode = uper_put_length(po, end - buf);
if (mayEncode < 0) _ASN_ENCODE_FAILED;
if (per_put_many_bits(po, buf, 8 * mayEncode)) _ASN_ENCODE_FAILED;
if (mayEncode < 0)
{
_ASN_ENCODE_FAILED;
}
if (per_put_many_bits(po, buf, 8 * mayEncode))
{
_ASN_ENCODE_FAILED;
}
buf += mayEncode;
}
@ -914,10 +1064,16 @@ int asn_INTEGER2long(const INTEGER_t *iptr, int64_t *lptr)
switch (*b)
{
case 0x00:
if ((b[1] & 0x80) == 0) continue;
if ((b[1] & 0x80) == 0)
{
continue;
}
break;
case 0xff:
if ((b[1] & 0x80) != 0) continue;
if ((b[1] & 0x80) != 0)
{
continue;
}
break;
}
break;
@ -942,12 +1098,19 @@ int asn_INTEGER2long(const INTEGER_t *iptr, int64_t *lptr)
/* Perform the sign initialization */
/* Actually l = -(*b >> 7); gains nothing, yet unreadable! */
if ((*b >> 7))
{
l = -1;
}
else
{
l = 0;
}
/* Conversion engine */
for (; b < end; b++) l = (l * 256) | *b;
for (; b < end; b++)
{
l = (l * 256) | *b;
}
*lptr = l;
return 0;
@ -982,7 +1145,10 @@ int asn_INTEGER2ulong(const INTEGER_t *iptr, uint64_t *lptr)
}
/* Conversion engine */
for (l = 0; b < end; b++) l = (l << 8) | *b;
for (l = 0; b < end; b++)
{
l = (l << 8) | *b;
}
*lptr = l;
return 0;
@ -995,17 +1161,28 @@ int asn_ulong2INTEGER(INTEGER_t *st, uint64_t value)
uint8_t *b;
int shr;
if (value <= LONG_MAX) return asn_long2INTEGER(st, value);
if (value <= LONG_MAX)
{
return asn_long2INTEGER(st, value);
}
buf = (uint8_t *)MALLOC(1 + sizeof(value));
if (!buf) return -1;
if (!buf)
{
return -1;
}
end = buf + (sizeof(value) + 1);
buf[0] = 0;
for (b = buf + 1, shr = (sizeof(int64_t) - 1) * 8; b < end; shr -= 8, b++)
{
*b = (uint8_t)(value >> shr);
}
if (st->buf) FREEMEM(st->buf);
if (st->buf)
{
FREEMEM(st->buf);
}
st->buf = buf;
st->size = 1 + sizeof(value);
@ -1029,7 +1206,10 @@ int asn_long2INTEGER(INTEGER_t *st, int64_t value)
}
buf = (uint8_t *)MALLOC(8);
if (!buf) return -1;
if (!buf)
{
return -1;
}
if (*(char *)&littleEndian)
{
@ -1055,18 +1235,30 @@ int asn_long2INTEGER(INTEGER_t *st, int64_t value)
switch (*p)
{
case 0x00:
if ((*(p + add) & 0x80) == 0) continue;
if ((*(p + add) & 0x80) == 0)
{
continue;
}
break;
case 0xff:
if ((*(p + add) & 0x80)) continue;
if ((*(p + add) & 0x80))
{
continue;
}
break;
}
break;
}
/* Copy the integer body */
for (pstart = p, bp = buf, pend1 += add; p != pend1; p += add) *bp++ = *p;
for (pstart = p, bp = buf, pend1 += add; p != pend1; p += add)
{
*bp++ = *p;
}
if (st->buf) FREEMEM(st->buf);
if (st->buf)
{
FREEMEM(st->buf);
}
st->buf = buf;
st->size = bp - buf;

View File

@ -48,7 +48,9 @@ static void LAC_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -30,7 +30,9 @@ static void LocErrorReason_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -50,7 +50,9 @@ static void MeasureResponseTime_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void ModuloTimeSlot_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -31,7 +31,9 @@ static void MoreAssDataToBeSent_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -29,7 +29,9 @@ static void MpathIndic_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -50,7 +50,9 @@ static void MultiFrameOffset_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -78,10 +78,14 @@ static enum xer_pbd_rval NULL__xer_body_decode(asn_TYPE_descriptor_t *td,
(void)sptr;
if (xer_is_whitespace(chunk_buf, chunk_size))
{
return XPBD_BODY_CONSUMED;
}
else
{
return XPBD_BROKEN_ENCODING;
}
}
asn_dec_rval_t NULL_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_descriptor_t *td, void **sptr,

View File

@ -56,7 +56,10 @@ asn_enc_rval_t NativeEnumerated_encode_xer(asn_TYPE_descriptor_t *td,
(void)ilevel;
(void)flags;
if (!native) _ASN_ENCODE_FAILED;
if (!native)
{
_ASN_ENCODE_FAILED;
}
el = INTEGER_map_value2enum(specs, *native);
if (el)
@ -66,7 +69,10 @@ asn_enc_rval_t NativeEnumerated_encode_xer(asn_TYPE_descriptor_t *td,
er.encoded = snprintf(src, srcsize, "<%s/>", el->enum_name);
assert(er.encoded > 0 && (size_t)er.encoded < srcsize);
if (cb(src, er.encoded, app_key) < 0) _ASN_ENCODE_FAILED;
if (cb(src, er.encoded, app_key) < 0)
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
else
@ -92,17 +98,29 @@ asn_dec_rval_t NativeEnumerated_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
(void)opt_codec_ctx;
if (constraints)
{
ct = &constraints->value;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->value;
}
else
{
_ASN_DECODE_FAILED; /* Mandatory! */
if (!specs) _ASN_DECODE_FAILED;
}
if (!specs)
{
_ASN_DECODE_FAILED;
}
if (!native)
{
native = (long *)(*sptr = CALLOC(1, sizeof(*native)));
if (!native) _ASN_DECODE_FAILED;
if (!native)
{
_ASN_DECODE_FAILED;
}
}
ASN_DEBUG("Decoding %s as NativeEnumerated", td->name);
@ -110,28 +128,48 @@ asn_dec_rval_t NativeEnumerated_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (ct->flags & APC_EXTENSIBLE)
{
int inext = per_get_few_bits(pd, 1);
if (inext < 0) _ASN_DECODE_STARVED;
if (inext) ct = 0;
if (inext < 0)
{
_ASN_DECODE_STARVED;
}
if (inext)
{
ct = 0;
}
}
if (ct && ct->range_bits >= 0)
{
value = per_get_few_bits(pd, ct->range_bits);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
if (value >=
(specs->extension ? specs->extension - 1 : specs->map_count))
{
_ASN_DECODE_FAILED;
}
}
else
{
if (!specs->extension) _ASN_DECODE_FAILED;
if (!specs->extension)
{
_ASN_DECODE_FAILED;
}
/*
* X.691, #10.6: normally small non-negative whole number;
*/
value = uper_get_nsnnwn(pd);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
value += specs->extension - 1;
if (value >= specs->map_count) _ASN_DECODE_FAILED;
if (value >= specs->map_count)
{
_ASN_DECODE_FAILED;
}
}
*native = specs->value2enum[value].nat_value;
@ -144,8 +182,14 @@ static int NativeEnumerated__compar_value2enum(const void *ap, const void *bp)
{
const asn_INTEGER_enum_map_t *a = ap;
const asn_INTEGER_enum_map_t *b = bp;
if (a->nat_value == b->nat_value) return 0;
if (a->nat_value < b->nat_value) return -1;
if (a->nat_value == b->nat_value)
{
return 0;
}
if (a->nat_value < b->nat_value)
{
return -1;
}
return 1;
}
@ -162,22 +206,37 @@ asn_enc_rval_t NativeEnumerated_encode_uper(asn_TYPE_descriptor_t *td,
asn_INTEGER_enum_map_t key;
asn_INTEGER_enum_map_t *kf;
if (!sptr) _ASN_ENCODE_FAILED;
if (!specs) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
if (!specs)
{
_ASN_ENCODE_FAILED;
}
if (constraints)
{
ct = &constraints->value;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->value;
}
else
{
_ASN_ENCODE_FAILED; /* Mandatory! */
}
ASN_DEBUG("Encoding %s as NativeEnumerated", td->name);
er.encoded = 0;
native = *(long *)sptr;
if (native < 0) _ASN_ENCODE_FAILED;
if (native < 0)
{
_ASN_ENCODE_FAILED;
}
key.nat_value = native;
kf = bsearch(&key, specs->value2enum, specs->map_count, sizeof(key),
@ -193,12 +252,21 @@ asn_enc_rval_t NativeEnumerated_encode_uper(asn_TYPE_descriptor_t *td,
{
int cmpWith =
specs->extension ? specs->extension - 1 : specs->map_count;
if (value >= cmpWith) inext = 1;
if (value >= cmpWith)
{
inext = 1;
}
}
if (ct->flags & APC_EXTENSIBLE)
{
if (per_put_few_bits(po, inext, 1)) _ASN_ENCODE_FAILED;
if (inext) ct = 0;
if (per_put_few_bits(po, inext, 1))
{
_ASN_ENCODE_FAILED;
}
if (inext)
{
ct = 0;
}
}
else if (inext)
{
@ -207,11 +275,17 @@ asn_enc_rval_t NativeEnumerated_encode_uper(asn_TYPE_descriptor_t *td,
if (ct && ct->range_bits >= 0)
{
if (per_put_few_bits(po, value, ct->range_bits)) _ASN_ENCODE_FAILED;
if (per_put_few_bits(po, value, ct->range_bits))
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
if (!specs->extension) _ASN_ENCODE_FAILED;
if (!specs->extension)
{
_ASN_ENCODE_FAILED;
}
/*
* X.691, #10.6: normally small non-negative whole number;
@ -220,7 +294,9 @@ asn_enc_rval_t NativeEnumerated_encode_uper(asn_TYPE_descriptor_t *td,
specs->extension, inext,
value - (inext ? (specs->extension - 1) : 0));
if (uper_put_nsnnwn(po, value - (inext ? (specs->extension - 1) : 0)))
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}

View File

@ -75,7 +75,10 @@ asn_dec_rval_t NativeInteger_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
*/
rval = ber_check_tags(opt_codec_ctx, td, 0, buf_ptr, size, tag_mode, 0,
&length, 0);
if (rval.code != RC_OK) return rval;
if (rval.code != RC_OK)
{
return rval;
}
ASN_DEBUG("%s length is %d bytes", td->name, (int)length);
@ -153,7 +156,9 @@ asn_enc_rval_t NativeInteger_encode_der(asn_TYPE_descriptor_t *sd, void *ptr,
/* Prepare a fake INTEGER */
for (p = buf + sizeof(buf) - 1; p >= buf; p--, native >>= 8)
{
*p = (uint8_t)native;
}
tmp.buf = buf;
tmp.size = sizeof(buf);
@ -186,7 +191,10 @@ asn_dec_rval_t NativeInteger_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
if (!native)
{
native = (long *)(*sptr = CALLOC(1, sizeof(*native)));
if (!native) _ASN_DECODE_FAILED;
if (!native)
{
_ASN_DECODE_FAILED;
}
}
memset(&st, 0, sizeof(st));
@ -234,14 +242,19 @@ asn_enc_rval_t NativeInteger_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
(void)ilevel;
(void)flags;
if (!native) _ASN_ENCODE_FAILED;
if (!native)
{
_ASN_ENCODE_FAILED;
}
er.encoded =
snprintf(scratch, sizeof(scratch),
(specs && specs->field_unsigned) ? "%lu" : "%ld", *native);
if (er.encoded <= 0 || (size_t)er.encoded >= sizeof(scratch) ||
cb(scratch, er.encoded, app_key) < 0)
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
@ -263,7 +276,10 @@ asn_dec_rval_t NativeInteger_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!native)
{
native = (int64_t *)(*sptr = CALLOC(1, sizeof(*native)));
if (!native) _ASN_DECODE_FAILED;
if (!native)
{
_ASN_DECODE_FAILED;
}
}
memset(&tmpint, 0, sizeof tmpint);
@ -273,10 +289,14 @@ asn_dec_rval_t NativeInteger_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if ((specs && specs->field_unsigned)
? asn_INTEGER2ulong(&tmpint, (uint64_t *)native)
: asn_INTEGER2long(&tmpint, native))
{
rval.code = RC_FAIL;
}
else
{
ASN_DEBUG("NativeInteger %s got value %ld", td->name, *native);
}
}
ASN_STRUCT_FREE_CONTENTS_ONLY(asn_DEF_INTEGER, &tmpint);
return rval;
@ -291,7 +311,10 @@ asn_enc_rval_t NativeInteger_encode_uper(asn_TYPE_descriptor_t *td,
long native;
INTEGER_t tmpint;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
native = *(long *)sptr;
@ -300,7 +323,9 @@ asn_enc_rval_t NativeInteger_encode_uper(asn_TYPE_descriptor_t *td,
memset(&tmpint, 0, sizeof(tmpint));
if ((specs && specs->field_unsigned) ? asn_ulong2INTEGER(&tmpint, native)
: asn_long2INTEGER(&tmpint, native))
{
_ASN_ENCODE_FAILED;
}
er = INTEGER_encode_uper(td, constraints, &tmpint, po);
ASN_STRUCT_FREE_CONTENTS_ONLY(asn_DEF_INTEGER, &tmpint);
return er;
@ -336,7 +361,10 @@ int NativeInteger_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
void NativeInteger_free(asn_TYPE_descriptor_t *td, void *ptr, int contents_only)
{
if (!td || !ptr) return;
if (!td || !ptr)
{
return;
}
ASN_DEBUG("Freeing %s as INTEGER (%d, %p, Native)", td->name, contents_only,
ptr);

View File

@ -50,7 +50,9 @@ static void NumOfMeasurements_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -156,7 +156,10 @@ static struct _stack_el *OS__add_stack_el(struct _stack *st)
else
{
nel = (struct _stack_el *)CALLOC(1, sizeof(struct _stack_el));
if (nel == NULL) return NULL;
if (nel == NULL)
{
return NULL;
}
if (st->tail)
{
@ -209,7 +212,10 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (st == NULL)
{
st = (BIT_STRING_t *)(*sptr = CALLOC(1, specs->struct_size));
if (st == NULL) RETURN(RC_FAIL);
if (st == NULL)
{
RETURN(RC_FAIL);
}
}
/* Restore parsing context */
@ -223,7 +229,10 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
*/
rval = ber_check_tags(opt_codec_ctx, td, ctx, buf_ptr, size,
tag_mode, -1, &ctx->left, &tlv_constr);
if (rval.code != RC_OK) return rval;
if (rval.code != RC_OK)
{
return rval;
}
if (tlv_constr)
{
@ -247,7 +256,9 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
*/
_CH_PHASE(ctx, 3);
if (type_variant == ASN_OSUBV_ANY && tag_mode != 1)
{
APPEND(buf_ptr, rval.consumed);
}
ADVANCE(rval.consumed);
goto phase3;
}
@ -286,12 +297,17 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (prev->left != -1)
{
if (prev->left < sel->got)
{
RETURN(RC_FAIL);
}
prev->left -= sel->got;
}
prev->got += sel->got;
sel = stck->cur_ptr = prev;
if (!sel) break;
if (!sel)
{
break;
}
tlv_constr = 1;
continue;
}
@ -344,7 +360,9 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (type_variant == ASN_OSUBV_ANY &&
(tag_mode != 1 || sel->cont_level))
{
APPEND("\0\0", 2);
}
ADVANCE(2);
sel->got += 2;
@ -430,7 +448,10 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
* Append a new expectation.
*/
sel = OS__add_stack_el(stck);
if (!sel) RETURN(RC_FAIL);
if (!sel)
{
RETURN(RC_FAIL);
}
sel->tag = tlv_tag;
@ -440,19 +461,27 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
/* Check that the parent frame is big enough */
if (sel->prev->left <
tlvl + (tlv_len == -1 ? 0 : tlv_len))
{
RETURN(RC_FAIL);
}
if (tlv_len == -1)
{
sel->left = sel->prev->left - tlvl;
}
else
{
sel->left = tlv_len;
}
}
else
{
sel->left = tlv_len;
}
if (type_variant == ASN_OSUBV_ANY &&
(tag_mode != 1 || sel->cont_level))
{
APPEND(buf_ptr, tlvl);
}
sel->got += tlvl;
ADVANCE(tlvl);
@ -526,7 +555,10 @@ asn_dec_rval_t OCTET_STRING_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (size < (size_t)ctx->left)
{
if (!size) RETURN(RC_WMORE);
if (!size)
{
RETURN(RC_WMORE);
}
if (type_variant == ASN_OSUBV_BIT && !ctx->context)
{
st->bits_unused = *(const uint8_t *)buf_ptr;
@ -638,7 +670,10 @@ asn_enc_rval_t OCTET_STRING_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
if (type_variant == ASN_OSUBV_BIT)
{
uint8_t b = st->bits_unused & 0x07;
if (b && st->size) fix_last_byte = 1;
if (b && st->size)
{
fix_last_byte = 1;
}
_ASN_CALLBACK(&b, 1);
er.encoded++;
}
@ -674,7 +709,10 @@ asn_enc_rval_t OCTET_STRING_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
uint8_t *end;
size_t i;
if (!st || (!st->buf && st->size)) _ASN_ENCODE_FAILED;
if (!st || (!st->buf && st->size))
{
_ASN_ENCODE_FAILED;
}
er.encoded = 0;
@ -721,7 +759,10 @@ asn_enc_rval_t OCTET_STRING_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
p--; /* Remove the tail space */
_ASN_CALLBACK(scratch, p - scratch); /* Dump the rest */
er.encoded += p - scratch;
if (st->size > 16) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (st->size > 16)
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
}
}
@ -818,8 +859,10 @@ static int OS__check_escaped_control_char(const void *buf, int size)
struct OCTET_STRING__xer_escape_table_s *el;
el = &OCTET_STRING__xer_escape_table[i];
if (el->size == size && memcmp(buf, el->string, size) == 0)
{
return i;
}
}
return -1;
}
@ -865,7 +908,10 @@ asn_enc_rval_t OCTET_STRING_encode_xer_utf8(asn_TYPE_descriptor_t *td,
(void)ilevel; /* Unused argument */
(void)flags; /* Unused argument */
if (!st || (!st->buf && st->size)) _ASN_ENCODE_FAILED;
if (!st || (!st->buf && st->size))
{
_ASN_ENCODE_FAILED;
}
buf = st->buf;
end = buf + st->size;
@ -884,14 +930,19 @@ asn_enc_rval_t OCTET_STRING_encode_xer_utf8(asn_TYPE_descriptor_t *td,
if (((buf - ss) && cb(ss, buf - ss, app_key) < 0) ||
cb(OCTET_STRING__xer_escape_table[ch].string, s_len,
app_key) < 0)
{
_ASN_ENCODE_FAILED;
}
encoded_len += (buf - ss) + s_len;
ss = buf + 1;
}
}
encoded_len += (buf - ss);
if ((buf - ss) && cb(ss, buf - ss, app_key) < 0) _ASN_ENCODE_FAILED;
if ((buf - ss) && cb(ss, buf - ss, app_key) < 0)
{
_ASN_ENCODE_FAILED;
}
er.encoded = encoded_len;
_ASN_ENCODED_OK(er);
@ -916,7 +967,10 @@ static ssize_t OCTET_STRING__convert_hexadecimal(void *sptr,
/* Reallocate buffer according to high cap estimation */
ssize_t _ns = st->size + (chunk_size + 1) / 2;
void *nptr = REALLOC(st->buf, _ns + 1);
if (!nptr) return -1;
if (!nptr)
{
return -1;
}
st->buf = (uint8_t *)nptr;
buf = st->buf + st->size;
@ -1019,16 +1073,23 @@ static ssize_t OCTET_STRING__convert_binary(void *sptr, const void *chunk_buf,
/* Reallocate buffer according to high cap estimation */
ssize_t _ns = st->size + (chunk_size + 7) / 8;
void *nptr = REALLOC(st->buf, _ns + 1);
if (!nptr) return -1;
if (!nptr)
{
return -1;
}
st->buf = (uint8_t *)nptr;
buf = st->buf + st->size;
(void)have_more;
if (bits_unused == 0)
{
bits_unused = 8;
}
else if (st->size)
{
buf--;
}
/*
* Convert series of 0 and 1 into the octet string.
@ -1091,7 +1152,10 @@ static int OS__strtoent(int base, const char *buf, const char *end,
int ch = *p;
/* Strange huge value */
if ((val * base + base) < 0) return -1;
if ((val * base + base) < 0)
{
return -1;
}
switch (ch)
{
@ -1149,7 +1213,10 @@ static ssize_t OCTET_STRING__convert_entrefs(void *sptr, const void *chunk_buf,
/* Reallocate buffer */
ssize_t _ns = st->size + chunk_size;
void *nptr = REALLOC(st->buf, _ns + 1);
if (!nptr) return -1;
if (!nptr)
{
return -1;
}
st->buf = (uint8_t *)nptr;
buf = st->buf + st->size;
@ -1171,18 +1238,28 @@ static ssize_t OCTET_STRING__convert_entrefs(void *sptr, const void *chunk_buf,
* Process entity reference.
*/
len = chunk_size - (p - (const char *)chunk_buf);
if (len == 1 /* "&" */) goto want_more;
if (len == 1 /* "&" */)
{
goto want_more;
}
if (p[1] == 0x23 /* '#' */)
{
const char *pval; /* Pointer to start of digits */
int32_t val = 0; /* Entity reference value */
int base;
if (len == 2 /* "&#" */) goto want_more;
if (len == 2 /* "&#" */)
{
goto want_more;
}
if (p[2] == 0x78 /* 'x' */)
{
pval = p + 3, base = 16;
}
else
{
pval = p + 2, base = 10;
}
len = OS__strtoent(base, pval, p + len, &val);
if (len == -1)
{
@ -1190,7 +1267,10 @@ static ssize_t OCTET_STRING__convert_entrefs(void *sptr, const void *chunk_buf,
*buf++ = ch;
continue;
}
if (!len || pval[len - 1] != 0x3b) goto want_more;
if (!len || pval[len - 1] != 0x3b)
{
goto want_more;
}
assert(val > 0);
p += (pval - p) + len - 1; /* Advance past entref */
@ -1240,7 +1320,10 @@ static ssize_t OCTET_STRING__convert_entrefs(void *sptr, const void *chunk_buf,
* Ugly, limited parsing of &amp; &gt; &lt;
*/
char *sc = (char *)memchr(p, 0x3b, len > 5 ? 5 : len);
if (!sc) goto want_more;
if (!sc)
{
goto want_more;
}
if ((sc - p) == 4 && p[1] == 0x61 /* 'a' */
&& p[2] == 0x6d /* 'm' */
&& p[3] == 0x70 /* 'p' */)
@ -1329,7 +1412,10 @@ static asn_dec_rval_t OCTET_STRING__decode_xer(
{
st = (OCTET_STRING_t *)CALLOC(1, specs->struct_size);
*sptr = (void *)st;
if (!st) goto sta_failed;
if (!st)
{
goto sta_failed;
}
st_allocated = 1;
}
else
@ -1425,14 +1511,19 @@ static int OCTET_STRING_per_get_characters(asn_per_data_t *po, uint8_t *buf,
else if (pc && pc->code2value)
{
if (unit_bits > 16)
return 1; /* FATAL: can't have constrained
{
return 1;
} /* FATAL: can't have constrained
* UniversalString with more than
* 16 million code points */
for (; buf < end; buf += bpc)
{
int value;
int code = per_get_few_bits(po, unit_bits);
if (code < 0) return -1; /* WMORE */
if (code < 0)
{
return -1; /* WMORE */
}
value = pc->code2value(code);
if (value < 0)
{
@ -1472,7 +1563,10 @@ static int OCTET_STRING_per_get_characters(asn_per_data_t *po, uint8_t *buf,
{
int code = per_get_few_bits(po, unit_bits);
int ch = code + lb;
if (code < 0) return -1; /* WMORE */
if (code < 0)
{
return -1; /* WMORE */
}
if (ch > ub)
{
ASN_DEBUG("Code %d is out of range (%ld..%ld)", ch, lb, ub);
@ -1546,7 +1640,10 @@ static int OCTET_STRING_per_put_characters(asn_per_outp_t *po,
*buf, *buf, lb, ub);
return -1;
}
if (per_put_few_bits(po, code, unit_bits)) return -1;
if (per_put_few_bits(po, code, unit_bits))
{
return -1;
}
}
}
@ -1584,7 +1681,10 @@ static int OCTET_STRING_per_put_characters(asn_per_outp_t *po,
*buf, *buf, lb, ub + lb);
return -1;
}
if (per_put_few_bits(po, ch, unit_bits)) return -1;
if (per_put_few_bits(po, ch, unit_bits))
{
return -1;
}
}
return 0;
@ -1640,17 +1740,26 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
break;
case ASN_OSUBV_STR:
canonical_unit_bits = unit_bits = 8;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_CHAR;
break;
case ASN_OSUBV_U16:
canonical_unit_bits = unit_bits = 16;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_U16;
break;
case ASN_OSUBV_U32:
canonical_unit_bits = unit_bits = 32;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_U32;
break;
}
@ -1661,7 +1770,10 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = (BIT_STRING_t *)(*sptr = CALLOC(1, specs->struct_size));
if (!st) RETURN(RC_FAIL);
if (!st)
{
RETURN(RC_FAIL);
}
}
ASN_DEBUG("PER Decoding %s size %ld .. %ld bits %d",
@ -1671,7 +1783,10 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (csiz->flags & APC_EXTENSIBLE)
{
int inext = per_get_few_bits(pd, 1);
if (inext < 0) RETURN(RC_WMORE);
if (inext < 0)
{
RETURN(RC_WMORE);
}
if (inext)
{
csiz = &ASN_DEF_OCTET_STRING_CONSTRAINTS.size;
@ -1712,7 +1827,10 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
ret = OCTET_STRING_per_get_characters(
pd, st->buf, csiz->upper_bound, bpc, unit_bits,
cval->lower_bound, cval->upper_bound, pc);
if (ret > 0) RETURN(RC_FAIL);
if (ret > 0)
{
RETURN(RC_FAIL);
}
}
else
{
@ -1721,7 +1839,10 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
ret = per_get_many_bits(pd, st->buf, 0,
unit_bits * csiz->upper_bound);
}
if (ret < 0) RETURN(RC_WMORE);
if (ret < 0)
{
RETURN(RC_WMORE);
}
consumed_myself += unit_bits * csiz->upper_bound;
st->buf[st->size] = 0;
if (bpc == 0)
@ -1743,7 +1864,10 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
/* Get the PER length */
raw_len = uper_get_length(pd, csiz->effective_bits, &repeat);
if (raw_len < 0) RETURN(RC_WMORE);
if (raw_len < 0)
{
RETURN(RC_WMORE);
}
raw_len += csiz->lower_bound;
ASN_DEBUG("Got PER length eb %ld, len %ld, %s (%s)",
@ -1758,11 +1882,17 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
{
len_bits = raw_len;
len_bytes = (len_bits + 7) >> 3;
if (len_bits & 0x7) st->bits_unused = 8 - (len_bits & 0x7);
if (len_bits & 0x7)
{
st->bits_unused = 8 - (len_bits & 0x7);
}
/* len_bits be multiple of 16K if repeat is set */
}
p = REALLOC(st->buf, st->size + len_bytes + 1);
if (!p) RETURN(RC_FAIL);
if (!p)
{
RETURN(RC_FAIL);
}
st->buf = (uint8_t *)p;
if (bpc)
@ -1770,14 +1900,20 @@ asn_dec_rval_t OCTET_STRING_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
ret = OCTET_STRING_per_get_characters(
pd, &st->buf[st->size], raw_len, bpc, unit_bits,
cval->lower_bound, cval->upper_bound, pc);
if (ret > 0) RETURN(RC_FAIL);
if (ret > 0)
{
RETURN(RC_FAIL);
}
}
else
{
ret =
per_get_many_bits(pd, &st->buf[st->size], 0, len_bits);
}
if (ret < 0) RETURN(RC_WMORE);
if (ret < 0)
{
RETURN(RC_WMORE);
}
st->size += len_bytes;
}
while (repeat);
@ -1813,7 +1949,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
} bpc; /* Bytes per character */
int ct_extensible;
if (!st || (!st->buf && st->size)) _ASN_ENCODE_FAILED;
if (!st || (!st->buf && st->size))
{
_ASN_ENCODE_FAILED;
}
if (pc)
{
@ -1841,19 +1980,28 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
break;
case ASN_OSUBV_STR:
canonical_unit_bits = unit_bits = 8;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_CHAR;
sizeinunits = st->size;
break;
case ASN_OSUBV_U16:
canonical_unit_bits = unit_bits = 16;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_U16;
sizeinunits = st->size / 2;
break;
case ASN_OSUBV_U32:
canonical_unit_bits = unit_bits = 32;
if (cval->flags & APC_CONSTRAINED) unit_bits = cval->range_bits;
if (cval->flags & APC_CONSTRAINED)
{
unit_bits = cval->range_bits;
}
bpc = OS__BPC_U32;
sizeinunits = st->size / 4;
break;
@ -1880,9 +2028,11 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
inext = 1;
}
else
{
_ASN_ENCODE_FAILED;
}
}
}
else
{
inext = 0;
@ -1891,7 +2041,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
if (ct_extensible)
{
/* Declare whether length is [not] within extension root */
if (per_put_few_bits(po, inext, 1)) _ASN_ENCODE_FAILED;
if (per_put_few_bits(po, inext, 1))
{
_ASN_ENCODE_FAILED;
}
}
/* X.691, #16.5: zero-length encoding */
@ -1903,7 +2056,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
sizeinunits - csiz->lower_bound, csiz->effective_bits);
ret = per_put_few_bits(po, sizeinunits - csiz->lower_bound,
csiz->effective_bits);
if (ret) _ASN_ENCODE_FAILED;
if (ret)
{
_ASN_ENCODE_FAILED;
}
if (bpc)
{
ret = OCTET_STRING_per_put_characters(
@ -1915,7 +2071,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
ret =
per_put_many_bits(po, st->buf, sizeinunits * unit_bits);
}
if (ret) _ASN_ENCODE_FAILED;
if (ret)
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
@ -1923,7 +2082,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
if (sizeinunits == 0)
{
if (uper_put_length(po, 0)) _ASN_ENCODE_FAILED;
if (uper_put_length(po, 0))
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}
@ -1931,7 +2093,10 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
while (sizeinunits)
{
ssize_t maySave = uper_put_length(po, sizeinunits);
if (maySave < 0) _ASN_ENCODE_FAILED;
if (maySave < 0)
{
_ASN_ENCODE_FAILED;
}
ASN_DEBUG("Encoding %ld of %ld", (long)maySave, (long)sizeinunits);
@ -1945,12 +2110,19 @@ asn_enc_rval_t OCTET_STRING_encode_uper(asn_TYPE_descriptor_t *td,
{
ret = per_put_many_bits(po, buf, maySave * unit_bits);
}
if (ret) _ASN_ENCODE_FAILED;
if (ret)
{
_ASN_ENCODE_FAILED;
}
if (bpc)
{
buf += maySave * bpc;
}
else
{
buf += maySave >> 3;
}
sizeinunits -= maySave;
assert(!(maySave & 0x07) || !sizeinunits);
}
@ -1972,7 +2144,9 @@ int OCTET_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
(void)td; /* Unused argument */
if (!st || (!st->buf && st->size))
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
/*
* Dump the contents of the buffer in hexadecimal.
@ -1983,7 +2157,10 @@ int OCTET_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
{
if (!(i % 16) && (i || st->size > 16))
{
if (cb(scratch, p - scratch, app_key) < 0) return -1;
if (cb(scratch, p - scratch, app_key) < 0)
{
return -1;
}
_i_INDENT(1);
p = scratch;
}
@ -1995,7 +2172,10 @@ int OCTET_STRING_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
if (p > scratch)
{
p--; /* Remove the tail space */
if (cb(scratch, p - scratch, app_key) < 0) return -1;
if (cb(scratch, p - scratch, app_key) < 0)
{
return -1;
}
}
return 0;
@ -2030,7 +2210,10 @@ void OCTET_STRING_free(asn_TYPE_descriptor_t *td, void *sptr, int contents_only)
(asn_struct_ctx_t *)((char *)st + specs->ctx_offset);
struct _stack *stck;
if (!td || !st) return;
if (!td || !st)
{
return;
}
ASN_DEBUG("Freeing %s as OCTET STRING", td->name);
@ -2086,11 +2269,17 @@ int OCTET_STRING_fromBuf(OCTET_STRING_t *st, const char *str, int len)
}
/* Determine the original string size, if not explicitly given */
if (len < 0) len = strlen(str);
if (len < 0)
{
len = strlen(str);
}
/* Allocate and fill the memory */
buf = MALLOC(len + 1);
if (buf == NULL) return -1;
if (buf == NULL)
{
return -1;
}
memcpy(buf, str, len);
((uint8_t *)buf)[len] = '\0'; /* Couldn't use memcpy(len+1)! */

View File

@ -31,7 +31,9 @@ static void OTD_FirstSetMsrs_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_OTD_MeasurementWithID.uper_decoder;
td->uper_encoder = asn_DEF_OTD_MeasurementWithID.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_OTD_MeasurementWithID.per_constraints;
}
td->elements = asn_DEF_OTD_MeasurementWithID.elements;
td->elements_count = asn_DEF_OTD_MeasurementWithID.elements_count;
td->specifics = asn_DEF_OTD_MeasurementWithID.specifics;

View File

@ -52,7 +52,9 @@ static void OTD_MeasureInfo_5_Ext_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_SeqOfOTD_MsrElementRest.uper_decoder;
td->uper_encoder = asn_DEF_SeqOfOTD_MsrElementRest.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_SeqOfOTD_MsrElementRest.per_constraints;
}
td->elements = asn_DEF_SeqOfOTD_MsrElementRest.elements;
td->elements_count = asn_DEF_SeqOfOTD_MsrElementRest.elements_count;
td->specifics = asn_DEF_SeqOfOTD_MsrElementRest.specifics;

View File

@ -48,7 +48,9 @@ static void OTDValue_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -58,7 +58,9 @@ static void PositionData_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_BIT_STRING.uper_decoder;
td->uper_encoder = asn_DEF_BIT_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_BIT_STRING.per_constraints;
}
td->elements = asn_DEF_BIT_STRING.elements;
td->elements_count = asn_DEF_BIT_STRING.elements_count;
td->specifics = asn_DEF_BIT_STRING.specifics;

View File

@ -30,7 +30,9 @@ static void PositionMethod_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -48,7 +48,9 @@ static void RefQuality_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -31,7 +31,9 @@ static void ReferenceRelation_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -48,7 +48,9 @@ static void RelDistance_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void RelativeAlt_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void RequestIndex_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -50,7 +50,9 @@ static void RequiredResponseTime_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void RoughRTD_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void SVID_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -57,7 +57,9 @@ static void SVIDMASK_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_BIT_STRING.uper_decoder;
td->uper_encoder = asn_DEF_BIT_STRING.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_BIT_STRING.per_constraints;
}
td->elements = asn_DEF_BIT_STRING.elements;
td->elements_count = asn_DEF_BIT_STRING.elements_count;
td->specifics = asn_DEF_BIT_STRING.specifics;

View File

@ -48,7 +48,9 @@ static void SatelliteID_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void StdResolution_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void SystemInfoIndex_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void TA0_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void TA1_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void TA2_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -49,7 +49,9 @@ static void TLMReservedBits_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void TLMWord_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -48,7 +48,9 @@ static void TimeSlot_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
td->specifics = asn_DEF_NativeInteger.specifics;

View File

@ -30,7 +30,9 @@ static void TimeSlotScheme_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -30,7 +30,9 @@ static void UlPseudoSegInd_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -40,7 +40,9 @@ static void ephemE_17_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
/* td->specifics = asn_DEF_NativeInteger.specifics; // Defined
@ -159,7 +161,9 @@ static void ephemAPowerHalf_19_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_NativeInteger.uper_decoder;
td->uper_encoder = asn_DEF_NativeInteger.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_NativeInteger.per_constraints;
}
td->elements = asn_DEF_NativeInteger.elements;
td->elements_count = asn_DEF_NativeInteger.elements_count;
/* td->specifics = asn_DEF_NativeInteger.specifics; // Defined

View File

@ -30,7 +30,9 @@ static void UseMultipleSets_1_inherit_TYPE_descriptor(asn_TYPE_descriptor_t *td)
td->uper_decoder = asn_DEF_ENUMERATED.uper_decoder;
td->uper_encoder = asn_DEF_ENUMERATED.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_ENUMERATED.per_constraints;
}
td->elements = asn_DEF_ENUMERATED.elements;
td->elements_count = asn_DEF_ENUMERATED.elements_count;
/* td->specifics = asn_DEF_ENUMERATED.specifics; // Defined

View File

@ -31,7 +31,9 @@ static void VelocityEstimate_1_inherit_TYPE_descriptor(
td->uper_decoder = asn_DEF_INTEGER.uper_decoder;
td->uper_encoder = asn_DEF_INTEGER.uper_encoder;
if (!td->per_constraints)
{
td->per_constraints = asn_DEF_INTEGER.per_constraints;
}
td->elements = asn_DEF_INTEGER.elements;
td->elements_count = asn_DEF_INTEGER.elements_count;
td->specifics = asn_DEF_INTEGER.specifics;

View File

@ -17,7 +17,9 @@ void asn_sequence_del(void *asn_sequence_of_x, int number, int _do_free)
int n;
if (number < 0 || number >= as->count)
{
return; /* Nothing to delete */
}
if (_do_free && as->free)
{
@ -33,12 +35,17 @@ void asn_sequence_del(void *asn_sequence_of_x, int number, int _do_free)
*/
--as->count;
for (n = number; n < as->count; n++)
{
as->array[n] = as->array[n + 1];
}
/*
* Invoke the third-party function only when the state
* of the parent structure is consistent.
*/
if (ptr) as->free(ptr);
if (ptr)
{
as->free(ptr);
}
}
}

View File

@ -51,7 +51,10 @@ void asn_set_del(void *asn_set_of_x, int number, int _do_free)
if (as)
{
void *ptr;
if (number < 0 || number >= as->count) return;
if (number < 0 || number >= as->count)
{
return;
}
if (_do_free && as->free)
{
@ -68,7 +71,10 @@ void asn_set_del(void *asn_set_of_x, int number, int _do_free)
* Invoke the third-party function only when the state
* of the parent structure is consistent.
*/
if (ptr) as->free(ptr);
if (ptr)
{
as->free(ptr);
}
}
}
@ -85,7 +91,10 @@ void asn_set_empty(void *asn_set_of_x)
{
if (as->free)
{
while (as->count--) as->free(as->array[as->count]);
while (as->count--)
{
as->free(as->array[as->count]);
}
}
FREEMEM(as->array);
as->array = 0;

View File

@ -24,7 +24,10 @@ asn_dec_rval_t ber_decode_primitive(asn_codec_ctx_t *opt_codec_ctx,
if (st == NULL)
{
st = (ASN__PRIMITIVE_TYPE_t *)CALLOC(1, sizeof(*st));
if (st == NULL) _ASN_DECODE_FAILED;
if (st == NULL)
{
_ASN_DECODE_FAILED;
}
*sptr = (void *)st;
}
@ -35,7 +38,10 @@ asn_dec_rval_t ber_decode_primitive(asn_codec_ctx_t *opt_codec_ctx,
*/
rval = ber_check_tags(opt_codec_ctx, td, 0, buf_ptr, size, tag_mode, 0,
&length, 0);
if (rval.code != RC_OK) return rval;
if (rval.code != RC_OK)
{
return rval;
}
ASN_DEBUG("%s length is %d bytes", td->name, (int)length);
@ -124,13 +130,22 @@ void ASN__PRIMITIVE_TYPE_free(asn_TYPE_descriptor_t *td, void *sptr,
{
ASN__PRIMITIVE_TYPE_t *st = (ASN__PRIMITIVE_TYPE_t *)sptr;
if (!td || !sptr) return;
if (!td || !sptr)
{
return;
}
ASN_DEBUG("Freeing %s as a primitive type", td->name);
if (st->buf) FREEMEM(st->buf);
if (st->buf)
{
FREEMEM(st->buf);
}
if (!contents_only) FREEMEM(st);
if (!contents_only)
{
FREEMEM(st);
}
}
/*
@ -154,7 +169,9 @@ static int xer_decode__unexpected_tag(void *key, const void *chunk_buf,
if (arg->decoded_something)
{
if (xer_is_whitespace(chunk_buf, chunk_size))
{
return 0; /* Skip it. */
}
/*
* Decoding was done once already. Prohibit doing it again.
*/
@ -188,7 +205,10 @@ static ssize_t xer_decode__body(void *key, const void *chunk_buf,
if (arg->decoded_something)
{
if (xer_is_whitespace(chunk_buf, chunk_size)) return chunk_size;
if (xer_is_whitespace(chunk_buf, chunk_size))
{
return chunk_size;
}
/*
* Decoding was done once already. Prohibit doing it again.
*/
@ -244,7 +264,10 @@ asn_dec_rval_t xer_decode_primitive(
if (!*sptr)
{
*sptr = CALLOC(1, struct_size);
if (!*sptr) _ASN_DECODE_FAILED;
if (!*sptr)
{
_ASN_DECODE_FAILED;
}
}
memset(&s_ctx, 0, sizeof(s_ctx));
@ -291,9 +314,13 @@ asn_dec_rval_t xer_decode_primitive(
case RC_FAIL:
rc.consumed = 0;
if (s_arg.want_more)
{
rc.code = RC_WMORE;
}
else
{
_ASN_DECODE_FAILED;
}
break;
}
return rc;

View File

@ -92,7 +92,10 @@ asn_dec_rval_t ber_check_tags(asn_codec_ctx_t *opt_codec_ctx,
/*
* Make sure we didn't exceed the maximum stack size.
*/
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx)) RETURN(RC_FAIL);
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx))
{
RETURN(RC_FAIL);
}
/*
* So what does all this implicit skip stuff mean?
@ -317,11 +320,18 @@ asn_dec_rval_t ber_check_tags(asn_codec_ctx_t *opt_codec_ctx,
}
}
if (opt_tlv_form) *opt_tlv_form = tlv_constr;
if (opt_tlv_form)
{
*opt_tlv_form = tlv_constr;
}
if (expect_00_terminators)
{
*last_length = -expect_00_terminators;
}
else
{
*last_length = tlv_len;
}
RETURN(RC_OK);
}

View File

@ -12,7 +12,10 @@ ssize_t ber_fetch_length(int _is_constructed, const void *bufptr, size_t size,
const uint8_t *buf = (const uint8_t *)bufptr;
unsigned oct;
if (size == 0) return 0; /* Want more */
if (size == 0)
{
return 0; /* Want more */
}
oct = *buf;
if ((oct & 0x80) == 0)
@ -90,13 +93,19 @@ ssize_t ber_skip_length(asn_codec_ctx_t *opt_codec_ctx, int _is_constructed,
/*
* Make sure we didn't exceed the maximum stack size.
*/
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx)) return -1;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx))
{
return -1;
}
/*
* Determine the size of L in TLV.
*/
ll = ber_fetch_length(_is_constructed, ptr, size, &vlen);
if (ll <= 0) return ll;
if (ll <= 0)
{
return ll;
}
/*
* Definite length.
@ -104,7 +113,10 @@ ssize_t ber_skip_length(asn_codec_ctx_t *opt_codec_ctx, int _is_constructed,
if (vlen >= 0)
{
skip = ll + vlen;
if (skip > size) return 0; /* Want more */
if (skip > size)
{
return 0; /* Want more */
}
return skip;
}
@ -118,11 +130,17 @@ ssize_t ber_skip_length(asn_codec_ctx_t *opt_codec_ctx, int _is_constructed,
/* Fetch the tag */
tl = ber_fetch_tag(ptr, size, &tag);
if (tl <= 0) return tl;
if (tl <= 0)
{
return tl;
}
ll = ber_skip_length(opt_codec_ctx, BER_TLV_CONSTRUCTED(ptr),
((const char *)ptr) + tl, size - tl);
if (ll <= 0) return ll;
if (ll <= 0)
{
return ll;
}
skip += tl + ll;
@ -133,7 +151,9 @@ ssize_t ber_skip_length(asn_codec_ctx_t *opt_codec_ctx, int _is_constructed,
*/
if (((const uint8_t *)ptr)[0] == 0 &&
((const uint8_t *)ptr)[1] == 0)
{
return skip;
}
ptr = ((const char *)ptr) + tl + ll;
size -= tl + ll;
@ -152,7 +172,10 @@ size_t der_tlv_length_serialize(ber_tlv_len_t len, void *bufp, size_t size)
if (len <= 127)
{
/* Encoded in 1 octet */
if (size) *buf = (uint8_t)len;
if (size)
{
*buf = (uint8_t)len;
}
return 1;
}
@ -162,12 +185,19 @@ size_t der_tlv_length_serialize(ber_tlv_len_t len, void *bufp, size_t size)
for (required_size = 1, i = 8; i < 8 * sizeof(len); i += 8)
{
if (len >> i)
{
required_size++;
}
else
{
break;
}
}
if (size <= required_size) return required_size + 1;
if (size <= required_size)
{
return required_size + 1;
}
*buf++ = (uint8_t)(0x80 | required_size); /* Length of the encoding */
@ -175,7 +205,10 @@ size_t der_tlv_length_serialize(ber_tlv_len_t len, void *bufp, size_t size)
* Produce the len encoding, space permitting.
*/
end = buf + required_size;
for (i -= 8; buf < end; i -= 8, buf++) *buf = (uint8_t)(len >> i);
for (i -= 8; buf < end; i -= 8, buf++)
{
*buf = (uint8_t)(len >> i);
}
return required_size + 1;
}

View File

@ -12,7 +12,10 @@ ssize_t ber_fetch_tag(const void *ptr, size_t size, ber_tlv_tag_t *tag_r)
ber_tlv_tag_t tclass;
size_t skipped;
if (size == 0) return 0;
if (size == 0)
{
return 0;
}
val = *(const uint8_t *)ptr;
tclass = (val >> 6);
@ -98,7 +101,10 @@ ssize_t ber_tlv_tag_snprint(ber_tlv_tag_t tag, char *buf, size_t size)
}
ret = snprintf(buf, size, "[%s%u]", type, ((unsigned)tag) >> 2);
if (ret <= 0 && size) buf[0] = '\0'; /* against broken libc's */
if (ret <= 0 && size)
{
buf[0] = '\0'; /* against broken libc's */
}
return ret;
}
@ -124,7 +130,10 @@ size_t ber_tlv_tag_serialize(ber_tlv_tag_t tag, void *bufp, size_t size)
if (tval <= 30)
{
/* Encoded in 1 octet */
if (size) buf[0] = (tclass << 6) | tval;
if (size)
{
buf[0] = (tclass << 6) | tval;
}
return 1;
}
else if (size)
@ -139,18 +148,28 @@ size_t ber_tlv_tag_serialize(ber_tlv_tag_t tag, void *bufp, size_t size)
for (required_size = 1, i = 7; i < 8 * sizeof(tval); i += 7)
{
if (tval >> i)
{
required_size++;
}
else
{
break;
}
}
if (size < required_size) return required_size + 1;
if (size < required_size)
{
return required_size + 1;
}
/*
* Fill in the buffer, space permitting.
*/
end = buf + required_size - 1;
for (i -= 7; buf < end; i -= 7, buf++) *buf = 0x80 | ((tval >> i) & 0x7F);
for (i -= 7; buf < end; i -= 7, buf++)
{
*buf = 0x80 | ((tval >> i) & 0x7F);
}
*buf = (tval & 0x7F); /* Last octet without high bit */
return required_size + 1;

View File

@ -92,12 +92,18 @@ static int _search4tag(const void *ap, const void *bp)
ber_tlv_tag_t b_value = BER_TAG_VALUE(b->el_tag);
if (a_value == b_value)
{
return 0;
}
else if (a_value < b_value)
{
return -1;
}
else
{
return 1;
}
}
else if (a_class < b_class)
{
return -1;
@ -202,7 +208,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (tag_len)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -251,7 +260,9 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
{
case 0:
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -366,7 +377,10 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (tl)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -380,10 +394,14 @@ asn_dec_rval_t CHOICE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (LEFT < 2)
{
if (SIZE_VIOLATION)
{
RETURN(RC_FAIL);
}
else
{
RETURN(RC_WMORE);
}
}
else if (((const uint8_t *)ptr)[1] == 0)
{
/*
@ -424,7 +442,10 @@ asn_enc_rval_t CHOICE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
size_t computed_size = 0;
int present;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
ASN_DEBUG("%s %s as CHOICE", cb ? "Encoding" : "Estimating", td->name);
@ -483,12 +504,18 @@ asn_enc_rval_t CHOICE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
/* Encode member with its tag */
erval = elm->type->der_encoder(elm->type, memb_ptr, elm->tag_mode,
elm->tag, 0, 0);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
/* Encode CHOICE with parent or my own tag */
ret = der_write_tags(td, erval.encoded, tag_mode, 1, tag, cb,
app_key);
if (ret == -1) _ASN_ENCODE_FAILED;
if (ret == -1)
{
_ASN_ENCODE_FAILED;
}
computed_size += ret;
}
@ -497,7 +524,10 @@ asn_enc_rval_t CHOICE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
*/
erval = elm->type->der_encoder(elm->type, memb_ptr, elm->tag_mode, elm->tag,
cb, app_key);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
ASN_DEBUG("Encoded CHOICE member in %ld bytes (+%ld)", (long)erval.encoded,
(long)computed_size);
@ -576,7 +606,10 @@ int CHOICE_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
elm->memb_offset);
if (!memb_ptr)
{
if (elm->optional) return 0;
if (elm->optional)
{
return 0;
}
_ASN_CTFAIL(app_key, td, sptr,
"%s: mandatory CHOICE element %s "
"absent (%s:%d)",
@ -658,7 +691,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
if (st == 0)
{
st = *struct_ptr = CALLOC(1, specs->struct_size);
if (st == 0) RETURN(RC_FAIL);
if (st == 0)
{
RETURN(RC_FAIL);
}
}
/*
@ -666,7 +702,9 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
*/
ctx = (asn_struct_ctx_t *)((char *)st + specs->ctx_offset);
if (ctx->phase == 0 && !*xml_tag)
{
ctx->phase = 1; /* Skip the outer tag checking phase */
}
/*
* Phases of XER/XML processing:
@ -714,7 +752,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
XER_ADVANCE(tmprval.consumed);
ASN_DEBUG("XER/CHOICE: itdf: [%s] code=%d", elm->type->name,
tmprval.code);
if (tmprval.code != RC_OK) RETURN(tmprval.code);
if (tmprval.code != RC_OK)
{
RETURN(tmprval.code);
}
assert(_fetch_present_idx(st, specs->pres_offset,
specs->pres_size) == 0);
/* Record what we've got */
@ -788,7 +829,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
case XCT_BOTH:
break; /* No CHOICE? */
case XCT_CLOSING:
if (ctx->phase != 3) break;
if (ctx->phase != 3)
{
break;
}
XER_ADVANCE(ch_size);
ctx->phase = 5; /* Phase out */
RETURN(RC_OK);
@ -803,7 +847,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
case XCT_UNKNOWN_OP:
case XCT_UNKNOWN_BO:
if (ctx->phase != 1) break; /* Really unexpected */
if (ctx->phase != 1)
{
break; /* Really unexpected */
}
/*
* Search which inner member corresponds to this tag.
@ -832,7 +879,10 @@ asn_dec_rval_t CHOICE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
}
break;
}
if (edx != td->elements_count) continue;
if (edx != td->elements_count)
{
continue;
}
/* It is expected extension */
if (specs->ext_start != -1)
@ -885,7 +935,10 @@ asn_enc_rval_t CHOICE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
asn_enc_rval_t er;
int present;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
/*
* Figure out which CHOICE element is encoded.
@ -907,7 +960,10 @@ asn_enc_rval_t CHOICE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
if (elm->flags & ATF_POINTER)
{
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (!memb_ptr) _ASN_ENCODE_FAILED;
if (!memb_ptr)
{
_ASN_ENCODE_FAILED;
}
}
else
{
@ -916,19 +972,28 @@ asn_enc_rval_t CHOICE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
er.encoded = 0;
if (!(flags & XER_F_CANONICAL)) _i_ASN_TEXT_INDENT(1, ilevel);
if (!(flags & XER_F_CANONICAL))
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
_ASN_CALLBACK3("<", 1, mname, mlen, ">", 1);
tmper = elm->type->xer_encoder(elm->type, memb_ptr, ilevel + 1,
flags, cb, app_key);
if (tmper.encoded == -1) return tmper;
if (tmper.encoded == -1)
{
return tmper;
}
_ASN_CALLBACK3("</", 2, mname, mlen, ">", 1);
er.encoded += 5 + (2 * mlen) + tmper.encoded;
}
if (!(flags & XER_F_CANONICAL)) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (!(flags & XER_F_CANONICAL))
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
_ASN_ENCODED_OK(er);
cb_failed:
@ -949,7 +1014,10 @@ asn_dec_rval_t CHOICE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
void *st = *sptr;
int value;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx)) _ASN_DECODE_FAILED;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx))
{
_ASN_DECODE_FAILED;
}
/*
* Create the target structure if it is not present already.
@ -957,42 +1025,75 @@ asn_dec_rval_t CHOICE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = *sptr = CALLOC(1, specs->struct_size);
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
if (constraints)
{
ct = &constraints->value;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->value;
}
else
{
ct = 0;
}
if (ct && ct->flags & APC_EXTENSIBLE)
{
value = per_get_few_bits(pd, 1);
if (value < 0) _ASN_DECODE_STARVED;
if (value) ct = 0; /* Not restricted */
if (value < 0)
{
_ASN_DECODE_STARVED;
}
if (value)
{
ct = 0; /* Not restricted */
}
}
if (ct && ct->range_bits >= 0)
{
value = per_get_few_bits(pd, ct->range_bits);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
ASN_DEBUG("CHOICE %s got index %d in range %d", td->name, value,
ct->range_bits);
if (value > ct->upper_bound) _ASN_DECODE_FAILED;
if (value > ct->upper_bound)
{
_ASN_DECODE_FAILED;
}
}
else
{
if (specs->ext_start == -1) _ASN_DECODE_FAILED;
if (specs->ext_start == -1)
{
_ASN_DECODE_FAILED;
}
value = uper_get_nsnnwn(pd);
if (value < 0) _ASN_DECODE_STARVED;
if (value < 0)
{
_ASN_DECODE_STARVED;
}
value += specs->ext_start;
if (value >= td->elements_count) _ASN_DECODE_FAILED;
if (value >= td->elements_count)
{
_ASN_DECODE_FAILED;
}
}
/* Adjust if canonical order is different from natural order */
if (specs->canonical_order) value = specs->canonical_order[value];
if (specs->canonical_order)
{
value = specs->canonical_order[value];
}
/* Set presence to be able to free it later */
_set_present_idx(st, specs->pres_offset, specs->pres_size, value + 1);
@ -1022,8 +1123,10 @@ asn_dec_rval_t CHOICE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
}
if (rv.code != RC_OK)
{
ASN_DEBUG("Failed to decode %s in %s (CHOICE) %d", elm->name, td->name,
rv.code);
}
return rv;
}
@ -1037,16 +1140,25 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
void *memb_ptr;
int present;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
ASN_DEBUG("Encoding %s as CHOICE", td->name);
if (constraints)
{
ct = &constraints->value;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->value;
}
else
{
ct = 0;
}
present = _fetch_present_idx(sptr, specs->pres_offset, specs->pres_size);
@ -1055,12 +1167,19 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
* can't deduce what to encode in the choice type.
*/
if (present <= 0 || present > td->elements_count)
{
_ASN_ENCODE_FAILED;
}
else
{
present--;
}
/* Adjust if canonical order is different from natural order */
if (specs->canonical_order) present = specs->canonical_order[present];
if (specs->canonical_order)
{
present = specs->canonical_order[present];
}
ASN_DEBUG("Encoding %s CHOICE element %d", td->name, present);
@ -1070,7 +1189,10 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
{
if (ct->flags & APC_EXTENSIBLE)
{
if (per_put_few_bits(po, 1, 1)) _ASN_ENCODE_FAILED;
if (per_put_few_bits(po, 1, 1))
{
_ASN_ENCODE_FAILED;
}
}
else
{
@ -1080,14 +1202,22 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
}
}
if (ct && ct->flags & APC_EXTENSIBLE)
if (per_put_few_bits(po, 0, 1)) _ASN_ENCODE_FAILED;
{
if (per_put_few_bits(po, 0, 1))
{
_ASN_ENCODE_FAILED;
}
}
elm = &td->elements[present];
if (elm->flags & ATF_POINTER)
{
/* Member is a pointer to another structure */
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (!memb_ptr) _ASN_ENCODE_FAILED;
if (!memb_ptr)
{
_ASN_ENCODE_FAILED;
}
}
else
{
@ -1097,7 +1227,9 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
if (ct && ct->range_bits >= 0)
{
if (per_put_few_bits(po, present, ct->range_bits))
{
_ASN_ENCODE_FAILED;
}
return elm->type->uper_encoder(elm->type, elm->per_constraints,
memb_ptr, po);
@ -1105,12 +1237,19 @@ asn_enc_rval_t CHOICE_encode_uper(asn_TYPE_descriptor_t *td,
else
{
asn_enc_rval_t rval;
if (specs->ext_start == -1) _ASN_ENCODE_FAILED;
if (uper_put_nsnnwn(po, present - specs->ext_start))
if (specs->ext_start == -1)
{
_ASN_ENCODE_FAILED;
}
if (uper_put_nsnnwn(po, present - specs->ext_start))
{
_ASN_ENCODE_FAILED;
}
if (uper_open_type_put(elm->type, elm->per_constraints, memb_ptr,
po))
{
_ASN_ENCODE_FAILED;
}
rval.encoded = 0;
_ASN_ENCODED_OK(rval);
}
@ -1122,7 +1261,10 @@ int CHOICE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
asn_CHOICE_specifics_t *specs = (asn_CHOICE_specifics_t *)td->specifics;
int present;
if (!sptr) return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
if (!sptr)
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
/*
* Figure out which CHOICE element is encoded.
@ -1142,8 +1284,10 @@ int CHOICE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
memb_ptr = *(const void *const *)((const char *)sptr +
elm->memb_offset);
if (!memb_ptr)
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
}
else
{
memb_ptr =
@ -1155,8 +1299,10 @@ int CHOICE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
{
if (cb(elm->name, strlen(elm->name), app_key) < 0 ||
cb(": ", 2, app_key) < 0)
{
return -1;
}
}
return elm->type->print_struct(elm->type, memb_ptr, ilevel, cb,
app_key);
@ -1172,7 +1318,10 @@ void CHOICE_free(asn_TYPE_descriptor_t *td, void *ptr, int contents_only)
asn_CHOICE_specifics_t *specs = (asn_CHOICE_specifics_t *)td->specifics;
int present;
if (!td || !ptr) return;
if (!td || !ptr)
{
return;
}
ASN_DEBUG("Freeing %s as CHOICE", td->name);
@ -1192,7 +1341,10 @@ void CHOICE_free(asn_TYPE_descriptor_t *td, void *ptr, int contents_only)
if (elm->flags & ATF_POINTER)
{
memb_ptr = *(void **)((char *)ptr + elm->memb_offset);
if (memb_ptr) ASN_STRUCT_FREE(*elm->type, memb_ptr);
if (memb_ptr)
{
ASN_STRUCT_FREE(*elm->type, memb_ptr);
}
}
else
{

View File

@ -99,7 +99,10 @@ static int _t2e_cmp(const void *ap, const void *bp)
if (a_value == b_value)
{
if (a->el_no > b->el_no) return 1;
if (a->el_no > b->el_no)
{
return 1;
}
/*
* Important: we do not check
* for a->el_no <= b->el_no!
@ -107,10 +110,14 @@ static int _t2e_cmp(const void *ap, const void *bp)
return 0;
}
else if (a_value < b_value)
{
return -1;
}
else
{
return 1;
}
}
else if (a_class < b_class)
{
return -1;
@ -187,7 +194,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
}
if (ctx->left >= 0)
{
ctx->left += rval.consumed; /* ?Subtracted below! */
}
ADVANCE(rval.consumed);
NEXT_PHASE(ctx);
@ -217,7 +226,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
int use_bsearch;
int n;
if (ctx->step & 1) goto microphase2;
if (ctx->step & 1)
{
goto microphase2;
}
/*
* MICROPHASE 1: Synchronize decoding.
@ -259,7 +271,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (tag_len)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -270,10 +285,14 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (LEFT < 2)
{
if (SIZE_VIOLATION)
{
RETURN(RC_FAIL);
}
else
{
RETURN(RC_WMORE);
}
}
else if (((const uint8_t *)ptr)[1] == 0)
{
ASN_DEBUG("edx = %d, opt = %d, ec=%d",
@ -306,7 +325,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
use_bsearch = 0;
opt_edx_end = edx + elements[edx].optional + 1;
if (opt_edx_end > td->elements_count)
{
opt_edx_end = td->elements_count; /* Cap */
}
else if (opt_edx_end - edx > 8)
{
/* Limit the scope of linear search... */
@ -372,8 +393,14 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
t2m_l = t2m + t2m->toff_last;
for (t2m = t2m_f; t2m <= t2m_l; t2m++)
{
if (t2m->el_no > edx_max) break;
if (t2m->el_no < edx) continue;
if (t2m->el_no > edx_max)
{
break;
}
if (t2m->el_no < edx)
{
continue;
}
best = t2m;
}
if (best)
@ -428,7 +455,9 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
{
case 0:
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -524,7 +553,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (tl)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -538,10 +570,14 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (LEFT < 2)
{
if (SIZE_VIOLATION)
{
RETURN(RC_FAIL);
}
else
{
RETURN(RC_WMORE);
}
}
else if (((const uint8_t *)ptr)[1] == 0)
{
/*
@ -571,7 +607,10 @@ asn_dec_rval_t SEQUENCE_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (ll)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -612,7 +651,10 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (!memb_ptr)
{
if (elm->optional) continue;
if (elm->optional)
{
continue;
}
/* Mandatory element is missing */
_ASN_ENCODE_FAILED;
}
@ -623,7 +665,10 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
}
erval = elm->type->der_encoder(elm->type, memb_ptr, elm->tag_mode,
elm->tag, 0, 0);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
computed_size += erval.encoded;
ASN_DEBUG("Member %d %s estimated %ld bytes", edx, elm->name,
(long)erval.encoded);
@ -634,10 +679,16 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
*/
ret = der_write_tags(td, computed_size, tag_mode, 1, tag, cb, app_key);
ASN_DEBUG("Wrote tags: %ld (+%ld)", (long)ret, (long)computed_size);
if (ret == -1) _ASN_ENCODE_FAILED;
if (ret == -1)
{
_ASN_ENCODE_FAILED;
}
erval.encoded = computed_size + ret;
if (!cb) _ASN_ENCODED_OK(erval);
if (!cb)
{
_ASN_ENCODED_OK(erval);
}
/*
* Encode all members.
@ -651,7 +702,10 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
if (elm->flags & ATF_POINTER)
{
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
}
else
{
@ -659,17 +713,22 @@ asn_enc_rval_t SEQUENCE_encode_der(asn_TYPE_descriptor_t *td, void *sptr,
}
tmperval = elm->type->der_encoder(
elm->type, memb_ptr, elm->tag_mode, elm->tag, cb, app_key);
if (tmperval.encoded == -1) return tmperval;
if (tmperval.encoded == -1)
{
return tmperval;
}
computed_size -= tmperval.encoded;
ASN_DEBUG("Member %d %s of SEQUENCE %s encoded in %ld bytes", edx,
elm->name, td->name, (long)tmperval.encoded);
}
if (computed_size != 0)
{
/*
* Encoded size is not equal to the computed size.
*/
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(erval);
}
@ -717,7 +776,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
if (st == 0)
{
st = *struct_ptr = CALLOC(1, specs->struct_size);
if (st == 0) RETURN(RC_FAIL);
if (st == 0)
{
RETURN(RC_FAIL);
}
}
/*
@ -769,7 +831,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
memb_ptr2, elm->name,
buf_ptr, size);
XER_ADVANCE(tmprval.consumed);
if (tmprval.code != RC_OK) RETURN(tmprval.code);
if (tmprval.code != RC_OK)
{
RETURN(tmprval.code);
}
ctx->phase = 1; /* Back to body processing */
ctx->step = ++edx;
ASN_DEBUG("XER/SEQUENCE phase => %d, step => %d",
@ -827,7 +892,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
switch (tcv)
{
case XCT_CLOSING:
if (ctx->phase == 0) break;
if (ctx->phase == 0)
{
break;
}
ctx->phase = 0;
/* Fall through */
case XCT_BOTH:
@ -879,7 +947,9 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
*/
edx_end = edx + elements[edx].optional + 1;
if (edx_end > td->elements_count)
{
edx_end = td->elements_count;
}
for (n = edx; n < edx_end; n++)
{
elm = &td->elements[n];
@ -904,7 +974,10 @@ asn_dec_rval_t SEQUENCE_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
}
break;
}
if (n != edx_end) continue;
if (n != edx_end)
{
continue;
}
}
else
{
@ -965,7 +1038,10 @@ asn_enc_rval_t SEQUENCE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
int xcan = (flags & XER_F_CANONICAL);
int edx;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
er.encoded = 0;
@ -982,7 +1058,10 @@ asn_enc_rval_t SEQUENCE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (!memb_ptr)
{
if (elm->optional) continue;
if (elm->optional)
{
continue;
}
/* Mandatory element is missing */
_ASN_ENCODE_FAILED;
}
@ -992,19 +1071,28 @@ asn_enc_rval_t SEQUENCE_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
memb_ptr = (void *)((char *)sptr + elm->memb_offset);
}
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
_ASN_CALLBACK3("<", 1, mname, mlen, ">", 1);
/* Print the member itself */
tmper = elm->type->xer_encoder(elm->type, memb_ptr, ilevel + 1,
flags, cb, app_key);
if (tmper.encoded == -1) return tmper;
if (tmper.encoded == -1)
{
return tmper;
}
_ASN_CALLBACK3("</", 2, mname, mlen, ">", 1);
er.encoded += 5 + (2 * mlen) + tmper.encoded;
}
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
_ASN_ENCODED_OK(er);
cb_failed:
@ -1017,12 +1105,17 @@ int SEQUENCE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
int edx;
int ret;
if (!sptr) return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
if (!sptr)
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
/* Dump preamble */
if (cb(td->name, strlen(td->name), app_key) < 0 ||
cb(" ::= {", 6, app_key) < 0)
{
return -1;
}
for (edx = 0; edx < td->elements_count; edx++)
{
@ -1035,7 +1128,10 @@ int SEQUENCE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
elm->memb_offset);
if (!memb_ptr)
{
if (elm->optional) continue;
if (elm->optional)
{
continue;
}
/* Print <absent> line */
/* Fall through */
}
@ -1052,12 +1148,17 @@ int SEQUENCE_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
/* Print the member's name and stuff */
if (cb(elm->name, strlen(elm->name), app_key) < 0 ||
cb(": ", 2, app_key) < 0)
{
return -1;
}
/* Print the member itself */
ret = elm->type->print_struct(elm->type, memb_ptr, ilevel + 1, cb,
app_key);
if (ret) return ret;
if (ret)
{
return ret;
}
}
ilevel--;
@ -1070,7 +1171,10 @@ void SEQUENCE_free(asn_TYPE_descriptor_t *td, void *sptr, int contents_only)
{
int edx;
if (!td || !sptr) return;
if (!td || !sptr)
{
return;
}
ASN_DEBUG("Freeing %s as SEQUENCE", td->name);
@ -1081,7 +1185,10 @@ void SEQUENCE_free(asn_TYPE_descriptor_t *td, void *sptr, int contents_only)
if (elm->flags & ATF_POINTER)
{
memb_ptr = *(void **)((char *)sptr + elm->memb_offset);
if (memb_ptr) ASN_STRUCT_FREE(*elm->type, memb_ptr);
if (memb_ptr)
{
ASN_STRUCT_FREE(*elm->type, memb_ptr);
}
}
else
{
@ -1122,7 +1229,10 @@ int SEQUENCE_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
elm->memb_offset);
if (!memb_ptr)
{
if (elm->optional) continue;
if (elm->optional)
{
continue;
}
_ASN_CTFAIL(
app_key, td, sptr,
"%s: mandatory element %s absent (%s:%d)",
@ -1140,13 +1250,19 @@ int SEQUENCE_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
{
int ret = elm->memb_constraints(elm->type, memb_ptr,
ctfailcb, app_key);
if (ret) return ret;
if (ret)
{
return ret;
}
}
else
{
int ret = elm->type->check_constraints(elm->type, memb_ptr,
ctfailcb, app_key);
if (ret) return ret;
if (ret)
{
return ret;
}
/*
* Cannot inherit it earlier:
* need to make sure we get the updated version.
@ -1173,12 +1289,18 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
(void)constraints;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx)) _ASN_DECODE_FAILED;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx))
{
_ASN_DECODE_FAILED;
}
if (!st)
{
st = *sptr = CALLOC(1, specs->struct_size);
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
ASN_DEBUG("Decoding %s as SEQUENCE (UPER)", td->name);
@ -1187,7 +1309,10 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (specs->ext_before >= 0)
{
extpresent = per_get_few_bits(pd, 1);
if (extpresent < 0) _ASN_DECODE_STARVED;
if (extpresent < 0)
{
_ASN_DECODE_STARVED;
}
}
else
{
@ -1199,7 +1324,10 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (specs->roms_count)
{
opres = (uint8_t *)MALLOC(((specs->roms_count + 7) >> 3) + 1);
if (!opres) _ASN_DECODE_FAILED;
if (!opres)
{
_ASN_DECODE_FAILED;
}
/* Get the presence map */
if (per_get_many_bits(pd, opres, 0, specs->roms_count))
{
@ -1225,7 +1353,10 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
void *memb_ptr; /* Pointer to the member */
void **memb_ptr2; /* Pointer to that pointer */
if (IN_EXTENSION_GROUP(specs, edx)) continue;
if (IN_EXTENSION_GROUP(specs, edx))
{
continue;
}
/* Fetch the pointer to this member */
if (elm->flags & ATF_POINTER)
@ -1289,12 +1420,18 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
asn_per_data_t epmd;
bmlength = uper_get_nslength(pd);
if (bmlength < 0) _ASN_DECODE_STARVED;
if (bmlength < 0)
{
_ASN_DECODE_STARVED;
}
ASN_DEBUG("Extensions %d present in %s", bmlength, td->name);
epres = (uint8_t *)MALLOC((bmlength + 15) >> 3);
if (!epres) _ASN_DECODE_STARVED;
if (!epres)
{
_ASN_DECODE_STARVED;
}
/* Get the extensions map */
if (per_get_many_bits(pd, epres, 0, bmlength))
@ -1338,7 +1475,10 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
present = per_get_few_bits(&epmd, 1);
if (present <= 0)
{
if (present < 0) break; /* No more extensions */
if (present < 0)
{
break; /* No more extensions */
}
continue;
}
@ -1385,13 +1525,19 @@ asn_dec_rval_t SEQUENCE_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
asn_TYPE_member_t *elm = &td->elements[edx];
void **memb_ptr2; /* Pointer to member pointer */
if (!elm->default_value) continue;
if (!elm->default_value)
{
continue;
}
/* Fetch the pointer to this member */
if (elm->flags & ATF_POINTER)
{
memb_ptr2 = (void **)((char *)st + elm->memb_offset);
if (*memb_ptr2) continue;
if (*memb_ptr2)
{
continue;
}
}
else
{
@ -1418,7 +1564,10 @@ static int SEQUENCE_handle_extensions(asn_TYPE_descriptor_t *td, void *sptr,
int exts_count = 0;
int edx;
if (specs->ext_before < 0) return 0;
if (specs->ext_before < 0)
{
return 0;
}
/* Find out which extensions are present */
for (edx = specs->ext_after + 1; edx < td->elements_count; edx++)
@ -1454,13 +1603,18 @@ static int SEQUENCE_handle_extensions(asn_TYPE_descriptor_t *td, void *sptr,
exts_present += present;
/* Encode as presence marker */
if (po1 && per_put_few_bits(po1, present, 1)) return -1;
if (po1 && per_put_few_bits(po1, present, 1))
{
return -1;
}
/* Encode as open type field */
if (po2 && present &&
uper_open_type_put(elm->type, elm->per_constraints, *memb_ptr2,
po2))
{
return -1;
}
}
return exts_present ? exts_count : 0;
}
@ -1477,7 +1631,10 @@ asn_enc_rval_t SEQUENCE_encode_uper(asn_TYPE_descriptor_t *td,
(void)constraints;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
er.encoded = 0;
@ -1524,13 +1681,18 @@ asn_enc_rval_t SEQUENCE_encode_uper(asn_TYPE_descriptor_t *td,
/* Eliminate default values */
if (present && elm->default_value &&
elm->default_value(0, memb_ptr2) == 1)
{
present = 0;
}
ASN_DEBUG("Element %s %s %s->%s is %s",
elm->flags & ATF_POINTER ? "ptr" : "inline",
elm->default_value ? "def" : "wtv", td->name, elm->name,
present ? "present" : "absent");
if (per_put_few_bits(po, present, 1)) _ASN_ENCODE_FAILED;
if (per_put_few_bits(po, present, 1))
{
_ASN_ENCODE_FAILED;
}
}
/*
@ -1546,7 +1708,10 @@ asn_enc_rval_t SEQUENCE_encode_uper(asn_TYPE_descriptor_t *td,
void *memb_ptr; /* Pointer to the member */
void **memb_ptr2; /* Pointer to that pointer */
if (IN_EXTENSION_GROUP(specs, edx)) continue;
if (IN_EXTENSION_GROUP(specs, edx))
{
continue;
}
ASN_DEBUG("About to encode %s", elm->type->name);
@ -1558,7 +1723,10 @@ asn_enc_rval_t SEQUENCE_encode_uper(asn_TYPE_descriptor_t *td,
{
ASN_DEBUG("Element %s %d not present", elm->name,
edx);
if (elm->optional) continue;
if (elm->optional)
{
continue;
}
/* Mandatory element is missing */
_ASN_ENCODE_FAILED;
}
@ -1571,31 +1739,46 @@ asn_enc_rval_t SEQUENCE_encode_uper(asn_TYPE_descriptor_t *td,
/* Eliminate default values */
if (elm->default_value && elm->default_value(0, memb_ptr2) == 1)
{
continue;
}
ASN_DEBUG("Encoding %s->%s", td->name, elm->name);
er = elm->type->uper_encoder(elm->type, elm->per_constraints,
*memb_ptr2, po);
if (er.encoded == -1) return er;
if (er.encoded == -1)
{
return er;
}
}
/* No extensions to encode */
if (!n_extensions) _ASN_ENCODED_OK(er);
if (!n_extensions)
{
_ASN_ENCODED_OK(er);
}
ASN_DEBUG("Length of %d bit-map", n_extensions);
/* #18.8. Write down the presence bit-map length. */
if (uper_put_nslength(po, n_extensions)) _ASN_ENCODE_FAILED;
if (uper_put_nslength(po, n_extensions))
{
_ASN_ENCODE_FAILED;
}
ASN_DEBUG("Bit-map of %d elements", n_extensions);
/* #18.7. Encoding the extensions presence bit-map. */
/* TODO: act upon NOTE in #18.7 for canonical PER */
if (SEQUENCE_handle_extensions(td, sptr, po, 0) != n_extensions)
{
_ASN_ENCODE_FAILED;
}
ASN_DEBUG("Writing %d extensions", n_extensions);
/* #18.9. Encode extensions as open type fields. */
if (SEQUENCE_handle_extensions(td, sptr, 0, po) != n_extensions)
{
_ASN_ENCODE_FAILED;
}
_ASN_ENCODED_OK(er);
}

View File

@ -30,10 +30,16 @@ asn_enc_rval_t SEQUENCE_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
for (edx = 0; edx < list->count; edx++)
{
void *memb_ptr = list->array[edx];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
erval =
elm->type->der_encoder(elm->type, memb_ptr, 0, elm->tag, 0, 0);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
computed_size += erval.encoded;
}
@ -65,10 +71,16 @@ asn_enc_rval_t SEQUENCE_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
for (edx = 0; edx < list->count; edx++)
{
void *memb_ptr = list->array[edx];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
erval = elm->type->der_encoder(elm->type, memb_ptr, 0, elm->tag, cb,
app_key);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
encoding_size += erval.encoded;
}
@ -108,7 +120,10 @@ asn_enc_rval_t SEQUENCE_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
int xcan = (flags & XER_F_CANONICAL);
int i;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
er.encoded = 0;
@ -116,22 +131,34 @@ asn_enc_rval_t SEQUENCE_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
{
asn_enc_rval_t tmper;
void *memb_ptr = list->array[i];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
if (mname)
{
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
_ASN_CALLBACK3("<", 1, mname, mlen, ">", 1);
}
tmper = elm->type->xer_encoder(elm->type, memb_ptr, ilevel + 1,
flags, cb, app_key);
if (tmper.encoded == -1) return tmper;
if (tmper.encoded == -1)
{
return tmper;
}
if (tmper.encoded == 0 && specs->as_XMLValueList)
{
const char *name = elm->type->xml_tag;
size_t len = strlen(name);
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel + 1);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel + 1);
}
_ASN_CALLBACK3("<", 1, name, len, "/>", 2);
}
@ -144,7 +171,10 @@ asn_enc_rval_t SEQUENCE_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
er.encoded += (2 * mlen) + tmper.encoded;
}
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
_ASN_ENCODED_OK(er);
cb_failed:
@ -161,7 +191,10 @@ asn_enc_rval_t SEQUENCE_OF_encode_uper(asn_TYPE_descriptor_t *td,
asn_TYPE_member_t *elm = td->elements;
int seq;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
list = _A_SEQUENCE_FROM_VOID(sptr);
er.encoded = 0;
@ -169,11 +202,17 @@ asn_enc_rval_t SEQUENCE_OF_encode_uper(asn_TYPE_descriptor_t *td,
ASN_DEBUG("Encoding %s as SEQUENCE OF (%d)", td->name, list->count);
if (constraints)
{
ct = &constraints->size;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->size;
}
else
{
ct = 0;
}
/* If extensible constraint, check if size is in root */
if (ct)
@ -186,25 +225,37 @@ asn_enc_rval_t SEQUENCE_OF_encode_uper(asn_TYPE_descriptor_t *td,
{
/* Declare whether size is in extension root */
if (per_put_few_bits(po, not_in_root, 1))
{
_ASN_ENCODE_FAILED;
if (not_in_root) ct = 0;
}
if (not_in_root)
{
ct = 0;
}
}
else if (not_in_root && ct->effective_bits >= 0)
{
_ASN_ENCODE_FAILED;
}
}
if (ct && ct->effective_bits >= 0)
{
/* X.691, #19.5: No length determinant */
if (per_put_few_bits(po, list->count - ct->lower_bound,
ct->effective_bits))
{
_ASN_ENCODE_FAILED;
}
}
for (seq = -1; seq < list->count;)
{
ssize_t mayEncode;
if (seq < 0) seq = 0;
if (seq < 0)
{
seq = 0;
}
if (ct && ct->effective_bits >= 0)
{
mayEncode = list->count;
@ -212,16 +263,25 @@ asn_enc_rval_t SEQUENCE_OF_encode_uper(asn_TYPE_descriptor_t *td,
else
{
mayEncode = uper_put_length(po, list->count - seq);
if (mayEncode < 0) _ASN_ENCODE_FAILED;
if (mayEncode < 0)
{
_ASN_ENCODE_FAILED;
}
}
while (mayEncode--)
{
void *memb_ptr = list->array[seq++];
if (!memb_ptr) _ASN_ENCODE_FAILED;
if (!memb_ptr)
{
_ASN_ENCODE_FAILED;
}
er = elm->type->uper_encoder(
elm->type, elm->per_constraints, memb_ptr, po);
if (er.encoded == -1) _ASN_ENCODE_FAILED;
if (er.encoded == -1)
{
_ASN_ENCODE_FAILED;
}
}
}

View File

@ -140,7 +140,9 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
}
if (ctx->left >= 0)
{
ctx->left += rval.consumed; /* ?Subtracted below! */
}
ADVANCE(rval.consumed);
ASN_DEBUG(
@ -160,7 +162,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
{
ssize_t tag_len; /* Length of TLV's T */
if (ctx->step & 1) goto microphase2;
if (ctx->step & 1)
{
goto microphase2;
}
/*
* MICROPHASE 1: Synchronize decoding.
@ -184,7 +189,10 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
switch (tag_len)
{
case 0:
if (!SIZE_VIOLATION) RETURN(RC_WMORE);
if (!SIZE_VIOLATION)
{
RETURN(RC_WMORE);
}
/* Fall through */
case -1:
RETURN(RC_FAIL);
@ -195,10 +203,14 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
if (LEFT < 2)
{
if (SIZE_VIOLATION)
{
RETURN(RC_FAIL);
}
else
{
RETURN(RC_WMORE);
}
}
else if (((const uint8_t *)ptr)[1] == 0)
{
/*
@ -255,10 +267,14 @@ asn_dec_rval_t SET_OF_decode_ber(asn_codec_ctx_t *opt_codec_ctx,
asn_anonymous_set_ *list =
_A_SET_FROM_VOID(st);
if (ASN_SET_ADD(list, ctx->ptr) != 0)
{
RETURN(RC_FAIL);
}
else
{
ctx->ptr = 0;
}
}
break;
case RC_WMORE: /* More data expected */
if (!SIZE_VIOLATION)
@ -327,7 +343,10 @@ static int _el_addbytes(const void *buffer, size_t size, void *el_buf_ptr)
{
struct _el_buffer *el_buf = (struct _el_buffer *)el_buf_ptr;
if (el_buf->length + size > el_buf->size) return -1;
if (el_buf->length + size > el_buf->size)
{
return -1;
}
memcpy(el_buf->buf + el_buf->length, buffer, size);
@ -342,18 +361,26 @@ static int _el_buf_cmp(const void *ap, const void *bp)
size_t common_len;
if (a->length < b->length)
{
common_len = a->length;
}
else
{
common_len = b->length;
}
ret = memcmp(a->buf, b->buf, common_len);
if (ret == 0)
{
if (a->length < b->length)
{
ret = -1;
}
else if (a->length > b->length)
{
ret = 1;
}
}
return ret;
}
@ -386,15 +413,23 @@ asn_enc_rval_t SET_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
for (edx = 0; edx < list->count; edx++)
{
void *memb_ptr = list->array[edx];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
erval = der_encoder(elm_type, memb_ptr, 0, elm->tag, 0, 0);
if (erval.encoded == -1) return erval;
if (erval.encoded == -1)
{
return erval;
}
computed_size += erval.encoded;
/* Compute maximum encoding's size */
if (max_encoded_len < (size_t)erval.encoded)
{
max_encoded_len = erval.encoded;
}
}
/*
* Encode the TLV for the sequence itself.
@ -441,7 +476,10 @@ asn_enc_rval_t SET_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
void *memb_ptr = list->array[edx];
struct _el_buffer *encoded_el = &encoded_els[eels_count];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
/*
* Prepare space for encoding.
@ -454,7 +492,10 @@ asn_enc_rval_t SET_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
}
else
{
for (edx--; edx >= 0; edx--) FREEMEM(encoded_els[edx].buf);
for (edx--; edx >= 0; edx--)
{
FREEMEM(encoded_els[edx].buf);
}
FREEMEM(encoded_els);
erval.encoded = -1;
erval.failed_type = td;
@ -469,7 +510,10 @@ asn_enc_rval_t SET_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
encoded_el);
if (erval.encoded == -1)
{
for (; edx >= 0; edx--) FREEMEM(encoded_els[edx].buf);
for (; edx >= 0; edx--)
{
FREEMEM(encoded_els[edx].buf);
}
FREEMEM(encoded_els);
return erval;
}
@ -493,7 +537,9 @@ asn_enc_rval_t SET_OF_encode_der(asn_TYPE_descriptor_t *td, void *ptr,
/* Report encoded chunks to the application */
if (ret == 0 &&
cb(encoded_el->buf, encoded_el->length, app_key) < 0)
{
ret = -1;
}
FREEMEM(encoded_el->buf);
}
FREEMEM(encoded_els);
@ -558,7 +604,10 @@ asn_dec_rval_t SET_OF_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
if (st == 0)
{
st = *struct_ptr = CALLOC(1, specs->struct_size);
if (st == 0) RETURN(RC_FAIL);
if (st == 0)
{
RETURN(RC_FAIL);
}
}
/* Which tag is expected for the downstream */
@ -604,7 +653,9 @@ asn_dec_rval_t SET_OF_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
{
asn_anonymous_set_ *list = _A_SET_FROM_VOID(st);
if (ASN_SET_ADD(list, ctx->ptr) != 0)
{
RETURN(RC_FAIL);
}
ctx->ptr = 0;
XER_ADVANCE(tmprval.consumed);
}
@ -646,7 +697,10 @@ asn_dec_rval_t SET_OF_decode_xer(asn_codec_ctx_t *opt_codec_ctx,
switch (tcv)
{
case XCT_CLOSING:
if (ctx->phase == 0) break;
if (ctx->phase == 0)
{
break;
}
ctx->phase = 0;
/* Fall through */
case XCT_BOTH:
@ -705,7 +759,10 @@ static int SET_OF_encode_xer_callback(const void *buffer, size_t size,
{
size_t newsize = (t->size << 2) + size;
void *p = REALLOC(t->buffer, newsize);
if (!p) return -1;
if (!p)
{
return -1;
}
t->buffer = p;
t->size = newsize;
}
@ -719,12 +776,24 @@ static int SET_OF_xer_order(const void *aptr, const void *bptr)
const xer_tmp_enc_t *b = (const xer_tmp_enc_t *)bptr;
size_t minlen = a->offset;
int ret;
if (b->offset < minlen) minlen = b->offset;
if (b->offset < minlen)
{
minlen = b->offset;
}
/* Well-formed UTF-8 has this nice lexicographical property... */
ret = memcmp(a->buffer, b->buffer, minlen);
if (ret != 0) return ret;
if (a->offset == b->offset) return 0;
if (a->offset == minlen) return -1;
if (ret != 0)
{
return ret;
}
if (a->offset == b->offset)
{
return 0;
}
if (a->offset == minlen)
{
return -1;
}
return 1;
}
@ -747,12 +816,18 @@ asn_enc_rval_t SET_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
asn_app_consume_bytes_f *original_cb = cb;
int i;
if (!sptr) _ASN_ENCODE_FAILED;
if (!sptr)
{
_ASN_ENCODE_FAILED;
}
if (xcan)
{
encs = (xer_tmp_enc_t *)MALLOC(list->count * sizeof(encs[0]));
if (!encs) _ASN_ENCODE_FAILED;
if (!encs)
{
_ASN_ENCODE_FAILED;
}
cb = SET_OF_encode_xer_callback;
}
@ -763,7 +838,10 @@ asn_enc_rval_t SET_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
asn_enc_rval_t tmper;
void *memb_ptr = list->array[i];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
if (encs)
{
@ -774,12 +852,17 @@ asn_enc_rval_t SET_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
if (mname)
{
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel);
}
_ASN_CALLBACK3("<", 1, mname, mlen, ">", 1);
}
if (!xcan && specs->as_XMLValueList == 1)
{
_i_ASN_TEXT_INDENT(1, ilevel + 1);
}
tmper = elm->type->xer_encoder(
elm->type, memb_ptr, ilevel + (specs->as_XMLValueList != 2),
flags, cb, app_key);
@ -805,7 +888,10 @@ asn_enc_rval_t SET_OF_encode_xer(asn_TYPE_descriptor_t *td, void *sptr,
er.encoded += (2 * mlen) + tmper.encoded;
}
if (!xcan) _i_ASN_TEXT_INDENT(1, ilevel - 1);
if (!xcan)
{
_i_ASN_TEXT_INDENT(1, ilevel - 1);
}
if (encs)
{
@ -838,8 +924,10 @@ cleanup:
while (encs_count-- > 0)
{
if (encs[encs_count].buffer)
{
FREEMEM(encs[encs_count].buffer);
}
}
FREEMEM(encs);
}
_ASN_ENCODED_OK(er);
@ -853,23 +941,34 @@ int SET_OF_print(asn_TYPE_descriptor_t *td, const void *sptr, int ilevel,
int ret;
int i;
if (!sptr) return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
if (!sptr)
{
return (cb("<absent>", 8, app_key) < 0) ? -1 : 0;
}
/* Dump preamble */
if (cb(td->name, strlen(td->name), app_key) < 0 ||
cb(" ::= {", 6, app_key) < 0)
{
return -1;
}
for (i = 0; i < list->count; i++)
{
const void *memb_ptr = list->array[i];
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
_i_INDENT(1);
ret = elm->type->print_struct(elm->type, memb_ptr, ilevel + 1, cb,
app_key);
if (ret) return ret;
if (ret)
{
return ret;
}
}
ilevel--;
@ -895,7 +994,10 @@ void SET_OF_free(asn_TYPE_descriptor_t *td, void *ptr, int contents_only)
for (i = 0; i < list->count; i++)
{
void *memb_ptr = list->array[i];
if (memb_ptr) ASN_STRUCT_FREE(*elm->type, memb_ptr);
if (memb_ptr)
{
ASN_STRUCT_FREE(*elm->type, memb_ptr);
}
}
list->count = 0; /* No meaningful elements left */
@ -932,7 +1034,10 @@ int SET_OF_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
}
constr = elm->memb_constraints;
if (!constr) constr = elm->type->check_constraints;
if (!constr)
{
constr = elm->type->check_constraints;
}
/*
* Iterate over the members of an array.
@ -943,10 +1048,16 @@ int SET_OF_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
const void *memb_ptr = list->array[i];
int ret;
if (!memb_ptr) continue;
if (!memb_ptr)
{
continue;
}
ret = constr(elm->type, memb_ptr, ctfailcb, app_key);
if (ret) return ret;
if (ret)
{
return ret;
}
}
/*
@ -954,7 +1065,9 @@ int SET_OF_constraint(asn_TYPE_descriptor_t *td, const void *sptr,
* need to make sure we get the updated version.
*/
if (!elm->memb_constraints)
{
elm->memb_constraints = elm->type->check_constraints;
}
return 0;
}
@ -973,7 +1086,10 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
int repeat = 0;
ssize_t nelems;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx)) _ASN_DECODE_FAILED;
if (_ASN_STACK_OVERFLOW_CHECK(opt_codec_ctx))
{
_ASN_DECODE_FAILED;
}
/*
* Create the target structure if it is not present already.
@ -981,23 +1097,38 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
if (!st)
{
st = *sptr = CALLOC(1, specs->struct_size);
if (!st) _ASN_DECODE_FAILED;
if (!st)
{
_ASN_DECODE_FAILED;
}
}
list = _A_SET_FROM_VOID(st);
/* Figure out which constraints to use */
if (constraints)
{
ct = &constraints->size;
}
else if (td->per_constraints)
{
ct = &td->per_constraints->size;
}
else
{
ct = 0;
}
if (ct && ct->flags & APC_EXTENSIBLE)
{
int value = per_get_few_bits(pd, 1);
if (value < 0) _ASN_DECODE_STARVED;
if (value) ct = 0; /* Not restricted! */
if (value < 0)
{
_ASN_DECODE_STARVED;
}
if (value)
{
ct = 0; /* Not restricted! */
}
}
if (ct && ct->effective_bits >= 0)
@ -1006,7 +1137,10 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
nelems = per_get_few_bits(pd, ct->effective_bits);
ASN_DEBUG("Preparing to fetch %ld+%ld elements from %s",
(long)nelems, ct->lower_bound, td->name);
if (nelems < 0) _ASN_DECODE_STARVED;
if (nelems < 0)
{
_ASN_DECODE_STARVED;
}
nelems += ct->lower_bound;
}
else
@ -1022,7 +1156,10 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
&repeat);
ASN_DEBUG("Got to decode %d elements (eff %d)", (int)nelems,
(long)ct ? ct->effective_bits : -1);
if (nelems < 0) _ASN_DECODE_STARVED;
if (nelems < 0)
{
_ASN_DECODE_STARVED;
}
}
for (ssize_t k = 0; k < nelems; k++)
@ -1036,7 +1173,10 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
elm->type->name, rv.code, ptr);
if (rv.code == RC_OK)
{
if (ASN_SET_ADD(list, ptr) == 0) continue;
if (ASN_SET_ADD(list, ptr) == 0)
{
continue;
}
ASN_DEBUG("Failed to add element into %s",
td->name);
/* Fall through */
@ -1047,7 +1187,10 @@ asn_dec_rval_t SET_OF_decode_uper(asn_codec_ctx_t *opt_codec_ctx,
ASN_DEBUG("Failed decoding %s of %s (SET OF)",
elm->type->name, td->name);
}
if (ptr) ASN_STRUCT_FREE(*elm->type, ptr);
if (ptr)
{
ASN_STRUCT_FREE(*elm->type, ptr);
}
return rv;
}

View File

@ -20,9 +20,15 @@ ber_tlv_tag_t asn_TYPE_outmost_tag(asn_TYPE_descriptor_t *type_descriptor,
const void *struct_ptr, int tag_mode,
ber_tlv_tag_t tag)
{
if (tag_mode) return tag;
if (tag_mode)
{
return tag;
}
if (type_descriptor->tags_count) return type_descriptor->tags[0];
if (type_descriptor->tags_count)
{
return type_descriptor->tags[0];
}
return type_descriptor->outmost_tag(type_descriptor, struct_ptr, 0, 0);
}
@ -32,7 +38,10 @@ ber_tlv_tag_t asn_TYPE_outmost_tag(asn_TYPE_descriptor_t *type_descriptor,
*/
int asn_fprint(FILE *stream, asn_TYPE_descriptor_t *td, const void *struct_ptr)
{
if (!stream) stream = stdout;
if (!stream)
{
stream = stdout;
}
if (!td || !struct_ptr)
{
errno = EINVAL;
@ -40,10 +49,16 @@ int asn_fprint(FILE *stream, asn_TYPE_descriptor_t *td, const void *struct_ptr)
}
/* Invoke type-specific printer */
if (td->print_struct(td, struct_ptr, 1, _print2fp, stream)) return -1;
if (td->print_struct(td, struct_ptr, 1, _print2fp, stream))
{
return -1;
}
/* Terminate the output */
if (_print2fp("\n", 1, stream)) return -1;
if (_print2fp("\n", 1, stream))
{
return -1;
}
return fflush(stream);
}
@ -53,7 +68,10 @@ static int _print2fp(const void *buffer, size_t size, void *app_key)
{
FILE *stream = (FILE *)app_key;
if (fwrite(buffer, 1, size, stream) != size) return -1;
if (fwrite(buffer, 1, size, stream) != size)
{
return -1;
}
return 0;
}

View File

@ -49,7 +49,10 @@ static void _asn_i_ctfailcb(void *key, asn_TYPE_descriptor_t *td,
arg->failed_struct_ptr = sptr;
maxlen = arg->errlen;
if (maxlen <= 0) return;
if (maxlen <= 0)
{
return;
}
va_start(ap, fmt);
vlen = vsnprintf(arg->errbuf, maxlen, fmt, ap);
@ -91,7 +94,10 @@ int asn_check_constraints(asn_TYPE_descriptor_t *type_descriptor,
ret = type_descriptor->check_constraints(type_descriptor, struct_ptr,
_asn_i_ctfailcb, &arg);
if (ret == -1 && errlen) *errlen = arg.errlen;
if (ret == -1 && errlen)
{
*errlen = arg.errlen;
}
return ret;
}

View File

@ -75,7 +75,10 @@ static void junk_bytes_with_probability(uint8_t *, size_t, double prob);
static inline void DEBUG(const char *fmt, ...)
{
va_list ap;
if (!opt_debug) return;
if (!opt_debug)
{
return;
}
fprintf(stderr, "AD: ");
va_start(ap, fmt);
vfprintf(stderr, fmt, ap);
@ -92,12 +95,17 @@ int main(int ac, char *av[])
int ch;
/* Figure out if Unaligned PER needs to be default */
if (pduType->uper_decoder) iform = INP_PER;
if (pduType->uper_decoder)
{
iform = INP_PER;
}
/*
* Process the command-line arguments.
*/
while ((ch = getopt(ac, av, "i:o:1b:cdn:p:hs:" JUNKOPT)) != -1) switch (ch)
while ((ch = getopt(ac, av, "i:o:1b:cdn:p:hs:" JUNKOPT)) != -1)
{
switch (ch)
{
case 'i':
if (optarg[0] == 'b')
@ -241,10 +249,12 @@ int main(int ac, char *av[])
av[0]);
fprintf(stderr, "Where options are:\n");
if (pduType->uper_decoder)
{
fprintf(
stderr,
" -iper Input is in Unaligned PER (Packed "
"Encoding Rules) (DEFAULT)\n");
}
fprintf(stderr,
" -iber Input is in BER (Basic Encoding "
"Rules)%s\n",
@ -253,11 +263,13 @@ int main(int ac, char *av[])
" -ixer Input is in XER (XML Encoding "
"Rules)\n");
if (pduType->uper_encoder)
{
fprintf(
stderr,
" -oper Output in Unaligned PER (Packed "
"Encoding "
"Rules)\n");
}
fprintf(
stderr,
" -oder Output in DER (Distinguished Encoding "
@ -269,9 +281,11 @@ int main(int ac, char *av[])
" -onull Verify (decode) input, but do not "
"output\n");
if (pduType->uper_decoder)
{
fprintf(stderr,
" -per-nopad Assume PER PDUs are not padded "
"(-iper)\n");
}
#ifdef ASN_PDU_COLLECTION
fprintf(stderr,
" -p <PDU> Specify PDU type to decode\n"
@ -296,6 +310,7 @@ int main(int ac, char *av[])
(long)suggested_bufsize, _ASN_DEFAULT_STACK_MAX);
exit(EX_USAGE);
}
}
ac -= optind;
av += optind;
@ -423,7 +438,10 @@ int main(int ac, char *av[])
ASN_STRUCT_FREE(*pduType, structure);
}
if (file && file != stdin) fclose(file);
if (file && file != stdin)
{
fclose(file);
}
}
}
@ -453,7 +471,10 @@ static void buffer_dump()
{
uint8_t *p = DynamicBuffer.data + DynamicBuffer.offset;
uint8_t *e = p + DynamicBuffer.length - (DynamicBuffer.unbits ? 1 : 0);
if (!opt_debug) return;
if (!opt_debug)
{
return;
}
DEBUG("Buffer: { d=%p, o=%ld, l=%ld, u=%ld, a=%ld, s=%ld }",
DynamicBuffer.data, (long)DynamicBuffer.offset,
(long)DynamicBuffer.length, (long)DynamicBuffer.unbits,
@ -471,7 +492,9 @@ static void buffer_dump()
unsigned int shift;
fprintf(stderr, " ");
for (shift = 7; shift >= DynamicBuffer.unbits; shift--)
{
fprintf(stderr, "%c", ((*p >> shift) & 1) ? '1' : '0');
}
fprintf(stderr, " %ld:%ld\n", (long)DynamicBuffer.length - 1,
(long)8 - DynamicBuffer.unbits);
}
@ -491,7 +514,10 @@ static void buffer_shift_left(size_t offset, int bits)
uint8_t *end =
DynamicBuffer.data + DynamicBuffer.offset + DynamicBuffer.length - 1;
if (!bits) return;
if (!bits)
{
return;
}
DEBUG("Shifting left %d bits off %ld (o=%ld, u=%ld, l=%ld)", bits,
(long)offset, (long)DynamicBuffer.offset, (long)DynamicBuffer.unbits,
@ -576,7 +602,10 @@ static void buffer_shift_left(size_t offset, int bits)
*/
static void add_bytes_to_buffer(const void *data2add, size_t bytes)
{
if (bytes == 0) return;
if (bytes == 0)
{
return;
}
DEBUG("=> add_bytes(%ld) { o=%ld l=%ld u=%ld, s=%ld }", (long)bytes,
(long)DynamicBuffer.offset, (long)DynamicBuffer.length,
@ -733,13 +762,17 @@ static void *data_decode_from_file(asn_TYPE_descriptor_t *pduType, FILE *file,
break;
case INP_PER:
if (opt_nopad)
{
rval = uper_decode(opt_codec_ctx, pduType,
&structure, i_bptr, i_size, 0,
DynamicBuffer.unbits);
}
else
{
rval = uper_decode_complete(opt_codec_ctx, pduType,
&structure, i_bptr,
i_size);
}
switch (rval.code)
{
case RC_OK:
@ -800,7 +833,10 @@ static void *data_decode_from_file(asn_TYPE_descriptor_t *pduType, FILE *file,
switch (rval.code)
{
case RC_OK:
if (ecbits) buffer_shift_left(0, ecbits);
if (ecbits)
{
buffer_shift_left(0, ecbits);
}
DEBUG("RC_OK, finishing up with %ld+%d",
(long)rval.consumed, ecbits);
return structure;
@ -813,7 +849,10 @@ static void *data_decode_from_file(asn_TYPE_descriptor_t *pduType, FILE *file,
(long)DynamicBuffer.length,
(long)DynamicBuffer.unbits,
(long)DynamicBuffer.allocated);
if (!rd) tolerate_eof--;
if (!rd)
{
tolerate_eof--;
}
continue;
case RC_FAIL:
break;
@ -889,11 +928,15 @@ static int argument_is_stdin(char *av[], int idx)
{
/* This might be <stdin>, unless `./program -- -` */
if (strcmp(av[-1], "--") != 0)
{
return 1;
}
else
{
return 0;
}
}
}
static FILE *argument_to_file(char *av[], int idx)
{

View File

@ -39,7 +39,9 @@ static int encode_to_buffer_cb(const void *buffer, size_t size, void *key)
enc_to_buf_arg *arg = (enc_to_buf_arg *)key;
if (arg->left < size)
{
return -1; /* Data exceeds the available buffer size */
}
memcpy(arg->buffer, buffer, size);
arg->buffer = ((char *)arg->buffer) + size;
@ -114,8 +116,10 @@ ssize_t der_write_tags(asn_TYPE_descriptor_t *sd, size_t struct_length,
tags[0] = tag;
stag_offset = -1 + ((tag_mode == -1) && sd->tags_count);
for (i = 1; i < tags_count; i++)
{
tags[i] = sd->tags[i + stag_offset];
}
}
else
{
tags = sd->tags;
@ -123,7 +127,10 @@ ssize_t der_write_tags(asn_TYPE_descriptor_t *sd, size_t struct_length,
}
/* No tags to write */
if (tags_count == 0) return 0;
if (tags_count == 0)
{
return 0;
}
lens = (ssize_t *)alloca(tags_count * sizeof(lens[0]));
if (!lens)
@ -140,12 +147,18 @@ ssize_t der_write_tags(asn_TYPE_descriptor_t *sd, size_t struct_length,
for (i = tags_count - 1; i >= 0; --i)
{
lens[i] = der_write_TL(tags[i], overall_length, 0, 0, 0);
if (lens[i] == -1) return -1;
if (lens[i] == -1)
{
return -1;
}
overall_length += lens[i];
lens[i] = overall_length - lens[i];
}
if (!cb) return overall_length - struct_length;
if (!cb)
{
return overall_length - struct_length;
}
ASN_DEBUG("%s %s TL sequence (%d elements)", cb ? "Encoding" : "Estimating",
sd->name, tags_count);
@ -162,7 +175,10 @@ ssize_t der_write_tags(asn_TYPE_descriptor_t *sd, size_t struct_length,
_constr = (last_tag_form || i < (tags_count - 1));
len = der_write_TL(tags[i], lens[i], cb, app_key, _constr);
if (len == -1) return -1;
if (len == -1)
{
return -1;
}
}
return overall_length - struct_length;
@ -179,24 +195,39 @@ static ssize_t der_write_TL(ber_tlv_tag_t tag, ber_tlv_len_t len,
/* Serialize tag (T from TLV) into possibly zero-length buffer */
tmp = ber_tlv_tag_serialize(tag, buf, buf_size);
if (tmp == -1 || tmp > (ssize_t)sizeof(buf)) return -1;
if (tmp == -1 || tmp > (ssize_t)sizeof(buf))
{
return -1;
}
size += tmp;
/* Serialize length (L from TLV) into possibly zero-length buffer */
tmp = der_tlv_length_serialize(len, buf + size,
buf_size ? buf_size - size : 0);
if (tmp == -1) return -1;
if (tmp == -1)
{
return -1;
}
size += tmp;
if (size > sizeof(buf)) return -1;
if (size > sizeof(buf))
{
return -1;
}
/*
* If callback is specified, invoke it, and check its return value.
*/
if (cb)
{
if (constructed) *buf |= 0x20;
if (cb(buf, size, app_key) < 0) return -1;
if (constructed)
{
*buf |= 0x20;
}
if (cb(buf, size, app_key) < 0)
{
return -1;
}
}
return size;

View File

@ -58,7 +58,9 @@ asn_dec_rval_t uper_decode(asn_codec_ctx_t *opt_codec_ctx,
if (skip_bits < 0 || skip_bits > 7 || unused_bits < 0 || unused_bits > 7 ||
(unused_bits > 0 && !size))
{
_ASN_DECODE_FAILED;
}
/*
* Stack checker requires that the codec context
@ -85,12 +87,18 @@ asn_dec_rval_t uper_decode(asn_codec_ctx_t *opt_codec_ctx,
pd.buffer = (const uint8_t *)buffer;
pd.nboff = skip_bits;
pd.nbits = 8 * size - unused_bits; /* 8 is CHAR_BIT from <limits.h> */
if (pd.nboff > pd.nbits) _ASN_DECODE_FAILED;
if (pd.nboff > pd.nbits)
{
_ASN_DECODE_FAILED;
}
/*
* Invoke type-specific decoder.
*/
if (!td->uper_decoder) _ASN_DECODE_FAILED; /* PER is not compiled in */
if (!td->uper_decoder)
{
_ASN_DECODE_FAILED; /* PER is not compiled in */
}
rval = td->uper_decoder(opt_codec_ctx, td, 0, sptr, &pd);
if (rval.code == RC_OK)
{

View File

@ -25,7 +25,9 @@ static int encode_to_buffer_cb(const void *buffer, size_t size, void *key)
enc_to_buf_arg *arg = (enc_to_buf_arg *)key;
if (arg->left < size)
{
return -1; /* Data exceeds the available buffer size */
}
memcpy(arg->buffer, buffer, size);
arg->buffer = ((char *)arg->buffer) + size;
@ -42,7 +44,10 @@ asn_enc_rval_t uper_encode_to_buffer(asn_TYPE_descriptor_t *td, void *sptr,
key.buffer = buffer;
key.left = buffer_size;
if (td) ASN_DEBUG("Encoding \"%s\" using UNALIGNED PER", td->name);
if (td)
{
ASN_DEBUG("Encoding \"%s\" using UNALIGNED PER", td->name);
}
return uper_encode_internal(td, 0, sptr, encode_to_buffer_cb, &key);
}
@ -117,7 +122,10 @@ static int _uper_encode_flush_outp(asn_per_outp_t *po)
{
uint8_t *buf;
if (po->nboff == 0 && po->buffer == po->tmpspace) return 0;
if (po->nboff == 0 && po->buffer == po->tmpspace)
{
return 0;
}
buf = po->buffer + (po->nboff >> 3);
/* Make sure we account for the last, partially filled */
@ -143,7 +151,9 @@ static asn_enc_rval_t uper_encode_internal(asn_TYPE_descriptor_t *td,
* Invoke type-specific encoder.
*/
if (!td || !td->uper_encoder)
{
_ASN_ENCODE_FAILED; /* PER is not compiled in */
}
po.buffer = po.tmpspace;
po.nboff = 0;
@ -162,7 +172,10 @@ static asn_enc_rval_t uper_encode_internal(asn_TYPE_descriptor_t *td,
/* Set number of bits encoded to a firm value */
er.encoded = (po.flushed_bytes << 3) + bits_to_flush;
if (_uper_encode_flush_outp(&po)) _ASN_ENCODE_FAILED;
if (_uper_encode_flush_outp(&po))
{
_ASN_ENCODE_FAILED;
}
}
return er;

View File

@ -40,19 +40,31 @@ int uper_open_type_put(asn_TYPE_descriptor_t *td,
ASN_DEBUG("Open type put %s ...", td->name);
size = uper_encode_to_new_buffer(td, constraints, sptr, &buf);
if (size <= 0) return -1;
if (size <= 0)
{
return -1;
}
for (bptr = buf, toGo = size; toGo;)
{
ssize_t maySave = uper_put_length(po, toGo);
if (maySave < 0) break;
if (per_put_many_bits(po, bptr, maySave * 8)) break;
if (maySave < 0)
{
break;
}
if (per_put_many_bits(po, bptr, maySave * 8))
{
break;
}
bptr = (char *)bptr + maySave;
toGo -= maySave;
}
FREEMEM(buf);
if (toGo) return -1;
if (toGo)
{
return -1;
}
ASN_DEBUG("Open type put %s of length %d + overhead (1byte?)", td->name,
size);
@ -241,7 +253,10 @@ static asn_dec_rval_t GCC_NOTUSED uper_open_type_get_complex(
UPDRESTOREPD;
/* Skip data not consumed by the decoder */
if (arg.unclaimed) ASN_DEBUG("Getting unclaimed %d", arg.unclaimed);
if (arg.unclaimed)
{
ASN_DEBUG("Getting unclaimed %d", arg.unclaimed);
}
if (arg.unclaimed)
{
switch (per_skip_bits(pd, arg.unclaimed))
@ -288,10 +303,14 @@ int uper_open_type_skip(asn_codec_ctx_t *ctx, asn_per_data_t *pd)
rv = uper_open_type_get(ctx, &s_td, 0, 0, pd);
if (rv.code != RC_OK)
{
return -1;
}
else
{
return 0;
}
}
/*
* Internal functions.
@ -310,7 +329,9 @@ static asn_dec_rval_t uper_sot_suck(asn_codec_ctx_t *ctx,
(void)sptr;
while (per_get_few_bits(pd, 24) >= 0)
{
;
}
rv.code = RC_OK;
rv.consumed = pd->moved;
@ -340,7 +361,10 @@ static int uper_ugot_refill(asn_per_data_t *pd)
if (arg->unclaimed)
{
/* Refill the container */
if (per_get_few_bits(oldpd, 1)) return -1;
if (per_get_few_bits(oldpd, 1))
{
return -1;
}
if (oldpd->nboff == 0)
{
assert(0);
@ -362,7 +386,10 @@ static int uper_ugot_refill(asn_per_data_t *pd)
next_chunk_bytes = uper_get_length(oldpd, -1, &arg->repeat);
ASN_DEBUG("Open type LENGTH %d bytes at off %d, repeat %d",
next_chunk_bytes, oldpd->moved, arg->repeat);
if (next_chunk_bytes < 0) return -1;
if (next_chunk_bytes < 0)
{
return -1;
}
if (next_chunk_bytes == 0)
{
pd->refill = 0; /* No more refills, naturally */
@ -399,9 +426,13 @@ static int per_skip_bits(asn_per_data_t *pd, int skip_nbits)
{
int skip = 0;
if (skip_nbits < skip)
{
skip = skip_nbits;
}
else
{
skip = 24;
}
skip_nbits -= skip;
switch (per_get_few_bits(pd, skip))

Some files were not shown because too many files have changed in this diff Show More