Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
asn1c
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Libraries
asn1c
Commits
cfc16d35
Commit
cfc16d35
authored
Aug 30, 2017
by
Lev Walkin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
BIT STRING decode for OER
parent
aa7c5a63
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
122 additions
and
8 deletions
+122
-8
examples/sample.source.1609.2/Makefile
examples/sample.source.1609.2/Makefile
+1
-0
skeletons/BIT_STRING.c
skeletons/BIT_STRING.c
+2
-2
skeletons/BIT_STRING.h
skeletons/BIT_STRING.h
+2
-0
skeletons/BIT_STRING_oer.c
skeletons/BIT_STRING_oer.c
+101
-0
skeletons/Makefile.am
skeletons/Makefile.am
+1
-0
skeletons/constr_SEQUENCE_oer.c
skeletons/constr_SEQUENCE_oer.c
+14
-6
skeletons/file-dependencies
skeletons/file-dependencies
+1
-0
No files found.
examples/sample.source.1609.2/Makefile
View file @
cfc16d35
...
@@ -288,6 +288,7 @@ ASN_MODULE_SOURCES+=NativeEnumerated_oer.c
...
@@ -288,6 +288,7 @@ ASN_MODULE_SOURCES+=NativeEnumerated_oer.c
ASN_MODULE_SOURCES
+=
constr_SEQUENCE_oer.c
ASN_MODULE_SOURCES
+=
constr_SEQUENCE_oer.c
ASN_MODULE_SOURCES
+=
constr_CHOICE_oer.c
ASN_MODULE_SOURCES
+=
constr_CHOICE_oer.c
ASN_MODULE_SOURCES
+=
constr_SET_OF_oer.c
ASN_MODULE_SOURCES
+=
constr_SET_OF_oer.c
ASN_MODULE_SOURCES
+=
BIT_STRING_oer.c
ASN_CONVERTER_SOURCES
+=
pdu_collection.c
ASN_CONVERTER_SOURCES
+=
pdu_collection.c
...
...
skeletons/BIT_STRING.c
View file @
cfc16d35
...
@@ -30,8 +30,8 @@ asn_TYPE_operation_t asn_OP_BIT_STRING = {
...
@@ -30,8 +30,8 @@ asn_TYPE_operation_t asn_OP_BIT_STRING = {
0
,
0
,
0
,
0
,
#else
#else
0
,
BIT_STRING_decode_oer
,
0
,
BIT_STRING_encode_oer
,
#endif
/* ASN_DISABLE_OER_SUPPORT */
#endif
/* ASN_DISABLE_OER_SUPPORT */
#ifdef ASN_DISABLE_PER_SUPPORT
#ifdef ASN_DISABLE_PER_SUPPORT
0
,
0
,
...
...
skeletons/BIT_STRING.h
View file @
cfc16d35
...
@@ -28,6 +28,8 @@ asn_struct_print_f BIT_STRING_print; /* Human-readable output */
...
@@ -28,6 +28,8 @@ asn_struct_print_f BIT_STRING_print; /* Human-readable output */
asn_struct_compare_f
BIT_STRING_compare
;
asn_struct_compare_f
BIT_STRING_compare
;
asn_constr_check_f
BIT_STRING_constraint
;
asn_constr_check_f
BIT_STRING_constraint
;
xer_type_encoder_f
BIT_STRING_encode_xer
;
xer_type_encoder_f
BIT_STRING_encode_xer
;
oer_type_decoder_f
BIT_STRING_decode_oer
;
oer_type_encoder_f
BIT_STRING_encode_oer
;
#define BIT_STRING_free OCTET_STRING_free
#define BIT_STRING_free OCTET_STRING_free
#define BIT_STRING_decode_ber OCTET_STRING_decode_ber
#define BIT_STRING_decode_ber OCTET_STRING_decode_ber
...
...
skeletons/BIT_STRING_oer.c
0 → 100644
View file @
cfc16d35
/*
* Copyright (c) 2017 Lev Walkin <vlm@lionet.info>.
* All rights reserved.
* Redistribution and modifications are permitted subject to BSD license.
*/
#ifndef ASN_DISABLE_OER_SUPPORT
#include <asn_internal.h>
#include <BIT_STRING.h>
#include <errno.h>
asn_dec_rval_t
BIT_STRING_decode_oer
(
asn_codec_ctx_t
*
opt_codec_ctx
,
asn_TYPE_descriptor_t
*
td
,
const
asn_oer_constraints_t
*
constraints
,
void
**
sptr
,
const
void
*
ptr
,
size_t
size
)
{
BIT_STRING_t
*
st
=
(
BIT_STRING_t
*
)
*
sptr
;
const
asn_oer_constraints_t
*
cts
=
constraints
?
constraints
:
td
->
oer_constraints
;
ssize_t
ct_size
=
cts
?
cts
->
size
:
-
1
;
asn_dec_rval_t
rval
=
{
RC_OK
,
0
};
size_t
expected_length
=
0
;
(
void
)
opt_codec_ctx
;
if
(
!
st
)
{
st
=
(
BIT_STRING_t
*
)(
*
sptr
=
CALLOC
(
1
,
sizeof
(
*
st
)));
if
(
!
st
)
ASN__DECODE_FAILED
;
}
if
(
ct_size
>=
0
)
{
expected_length
=
(
ct_size
+
7
)
>>
3
;
st
->
bits_unused
=
(
8
-
(
ct_size
&
7
))
&
7
;
}
else
{
/*
* X.696 (08/2015) #13.3.1
* Encode length determinant as _number of octets_, but only
* if upper bound is not equal to lower bound.
*/
ssize_t
len_len
=
oer_fetch_length
(
ptr
,
size
,
&
expected_length
);
if
(
len_len
>
0
)
{
ptr
=
(
const
char
*
)
ptr
+
len_len
;
size
-=
len_len
;
}
else
if
(
len_len
==
0
)
{
ASN__DECODE_STARVED
;
}
else
if
(
len_len
<
0
)
{
ASN__DECODE_FAILED
;
}
if
(
expected_length
<
1
)
{
ASN__DECODE_STARVED
;
}
st
->
bits_unused
=
((
const
uint8_t
*
)
ptr
)[
0
];
if
(
st
->
bits_unused
&
~
7
)
{
ASN_DEBUG
(
"%s: unused bits outside of 0..7 range"
,
td
->
name
);
ASN__DECODE_FAILED
;
}
ptr
=
(
const
char
*
)
ptr
+
1
;
size
--
;
expected_length
--
;
rval
.
consumed
=
len_len
+
1
;
}
if
(
size
<
expected_length
)
{
ASN__DECODE_STARVED
;
}
else
{
uint8_t
*
buf
=
MALLOC
(
expected_length
+
1
);
if
(
buf
==
NULL
)
{
ASN__DECODE_FAILED
;
}
else
{
memcpy
(
buf
,
ptr
,
expected_length
);
buf
[
expected_length
]
=
'\0'
;
}
FREEMEM
(
st
->
buf
);
st
->
buf
=
buf
;
st
->
size
=
expected_length
;
if
(
expected_length
>
0
)
{
buf
[
expected_length
-
1
]
&=
(
0xff
<<
st
->
bits_unused
);
}
rval
.
consumed
+=
expected_length
;
return
rval
;
}
}
/*
* Encode as Canonical OER.
*/
asn_enc_rval_t
BIT_STRING_encode_oer
(
asn_TYPE_descriptor_t
*
td
,
const
asn_oer_constraints_t
*
constraints
,
void
*
sptr
,
asn_app_consume_bytes_f
*
cb
,
void
*
app_key
)
{
asn_enc_rval_t
er
=
{
-
1
,
td
,
sptr
};
(
void
)
constraints
;
(
void
)
cb
;
(
void
)
app_key
;
return
er
;
}
#endif
/* ASN_DISABLE_OER_SUPPORT */
skeletons/Makefile.am
View file @
cfc16d35
...
@@ -24,6 +24,7 @@ libasn1cskeletons_la_CFLAGS = $(SKELETONS_CFLAGS)
...
@@ -24,6 +24,7 @@ libasn1cskeletons_la_CFLAGS = $(SKELETONS_CFLAGS)
libasn1cskeletons_la_SOURCES
=
\
libasn1cskeletons_la_SOURCES
=
\
ANY.c ANY.h
\
ANY.c ANY.h
\
BIT_STRING.c BIT_STRING.h
\
BIT_STRING.c BIT_STRING.h
\
BIT_STRING_oer.c
\
BMPString.c BMPString.h
\
BMPString.c BMPString.h
\
BOOLEAN.c BOOLEAN.h
\
BOOLEAN.c BOOLEAN.h
\
ENUMERATED.c ENUMERATED.h
\
ENUMERATED.c ENUMERATED.h
\
...
...
skeletons/constr_SEQUENCE_oer.c
View file @
cfc16d35
...
@@ -54,10 +54,16 @@
...
@@ -54,10 +54,16 @@
/*
/*
* Return pointer to a member.
* Return pointer to a member.
*/
*/
static
void
**
element_ptrptr
(
void
*
struct_ptr
,
asn_TYPE_member_t
*
elm
)
{
static
void
**
assert
(
elm
->
flags
&
ATF_POINTER
);
element_ptrptr
(
void
*
struct_ptr
,
asn_TYPE_member_t
*
elm
,
void
**
tmp_save_ptr
)
{
if
(
elm
->
flags
&
ATF_POINTER
)
{
/* Member is a pointer to another structure */
/* Member is a pointer to another structure */
return
(
void
**
)((
char
*
)
struct_ptr
+
elm
->
memb_offset
);
return
(
void
**
)((
char
*
)
struct_ptr
+
elm
->
memb_offset
);
}
else
{
assert
(
tmp_save_ptr
);
*
tmp_save_ptr
=
(
void
*
)((
char
*
)
struct_ptr
+
elm
->
memb_offset
);
return
tmp_save_ptr
;
}
}
}
static
void
*
element_ptr
(
void
*
struct_ptr
,
asn_TYPE_member_t
*
elm
)
{
static
void
*
element_ptr
(
void
*
struct_ptr
,
asn_TYPE_member_t
*
elm
)
{
...
@@ -172,7 +178,9 @@ SEQUENCE_decode_oer(asn_codec_ctx_t *opt_codec_ctx, asn_TYPE_descriptor_t *td,
...
@@ -172,7 +178,9 @@ SEQUENCE_decode_oer(asn_codec_ctx_t *opt_codec_ctx, asn_TYPE_descriptor_t *td,
}
else
if
(
present
==
0
)
{
}
else
if
(
present
==
0
)
{
if
(
elm
->
default_value
)
{
if
(
elm
->
default_value
)
{
/* Fill-in DEFAULT */
/* Fill-in DEFAULT */
if
(
elm
->
default_value
(
1
,
element_ptrptr
(
st
,
elm
)))
{
void
*
tmp
;
if
(
elm
->
default_value
(
1
,
element_ptrptr
(
st
,
elm
,
&
tmp
)))
{
RETURN
(
RC_FAIL
);
RETURN
(
RC_FAIL
);
}
}
}
}
...
@@ -306,7 +314,7 @@ SEQUENCE_decode_oer(asn_codec_ctx_t *opt_codec_ctx, asn_TYPE_descriptor_t *td,
...
@@ -306,7 +314,7 @@ SEQUENCE_decode_oer(asn_codec_ctx_t *opt_codec_ctx, asn_TYPE_descriptor_t *td,
asn_bit_data_t
*
extadds
=
ctx
->
ptr
;
asn_bit_data_t
*
extadds
=
ctx
->
ptr
;
size_t
edx
=
ctx
->
step
;
size_t
edx
=
ctx
->
step
;
asn_TYPE_member_t
*
elm
=
&
td
->
elements
[
edx
];
asn_TYPE_member_t
*
elm
=
&
td
->
elements
[
edx
];
void
**
memb_ptr2
=
element_ptrptr
(
st
,
elm
);
void
**
memb_ptr2
=
element_ptrptr
(
st
,
elm
,
0
);
switch
(
asn_get_few_bits
(
extadds
,
1
))
{
switch
(
asn_get_few_bits
(
extadds
,
1
))
{
case
-
1
:
case
-
1
:
...
...
skeletons/file-dependencies
View file @
cfc16d35
...
@@ -79,5 +79,6 @@ NativeEnumerated_oer.c
...
@@ -79,5 +79,6 @@ NativeEnumerated_oer.c
constr_SEQUENCE_oer.c
constr_SEQUENCE_oer.c
constr_CHOICE_oer.c
constr_CHOICE_oer.c
constr_SET_OF_oer.c constr_SET_OF.h asn_SET_OF.h asn_SET_OF.c
constr_SET_OF_oer.c constr_SET_OF.h asn_SET_OF.h asn_SET_OF.c
BIT_STRING_oer.c
CODEC-PER: # THIS IS A SPECIAL SECTION
CODEC-PER: # THIS IS A SPECIAL SECTION
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment