diff options
author | Lev Walkin <vlm@lionet.info> | 2014-02-09 04:34:54 -0800 |
---|---|---|
committer | Lev Walkin <vlm@lionet.info> | 2014-02-09 04:34:54 -0800 |
commit | 6c52784de169a792156a4d1da1312097ff93d551 (patch) | |
tree | 2abae447808b38c9130b22cdc2b9efdc0ba14882 /asn1c/tests | |
parent | bfc76e8f1e3c96cb7ada29b13825019201945bfd (diff) |
PER-encoding of integers wider than 32 bits
Diffstat (limited to 'asn1c/tests')
-rw-r--r-- | asn1c/tests/check-134.-gen-PER.c | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/asn1c/tests/check-134.-gen-PER.c b/asn1c/tests/check-134.-gen-PER.c new file mode 100644 index 00000000..d129fe3b --- /dev/null +++ b/asn1c/tests/check-134.-gen-PER.c @@ -0,0 +1,115 @@ +/* + * Verify INTEGER values with greater than 32 bits range. + */ +#undef NDEBUG +#include <stdio.h> +#include <stdlib.h> +#include <sys/types.h> +#include <string.h> +#include <assert.h> +#include <ctype.h> +#include <errno.h> + +#include <T.h> + +#ifndef _LP64 +int main() { + assert(sizeof(void *) < 8); + return; +} +#else /* 64-bit platform */ + +static unsigned long i2ul(const INTEGER_t *i) { + unsigned long l; + int ret = asn_INTEGER2ulong(i, &l); + assert(ret == 0); + return l; +} + +static void ul2i(INTEGER_t *i, unsigned long l) { + int ret = asn_ulong2INTEGER(i, l); + assert(ret == 0); +} + +static void +verify(int testNo, T_t *ti) { + asn_enc_rval_t er; + asn_dec_rval_t rv; + unsigned char buf[16]; + T_t *to = 0; + + fprintf(stderr, "%d IN: { %lu, %lu }\n", testNo, + i2ul(&ti->unsigned33), i2ul(&ti->unsigned42)); + + er = uper_encode_to_buffer(&asn_DEF_T, ti, buf, sizeof buf); + assert(er.encoded == 33 + 42); + + rv = uper_decode(0, &asn_DEF_T, (void *)&to, buf, sizeof buf, 0, 0); + assert(rv.code == RC_OK); + + fprintf(stderr, "%d ENC: %2x%2x%2x%2x %2x%2x%2x%2x\n", testNo, + buf[0], buf[1], buf[2], buf[3], + buf[4], buf[5], buf[6], buf[7]); + fprintf(stderr, "%d OUT: { %lu, %lu } vs { %lu, %lu }\n", + testNo, + i2ul(&ti->unsigned33), i2ul(&ti->unsigned42), + i2ul(&to->unsigned33), i2ul(&to->unsigned42)); + assert(i2ul(&ti->unsigned33) == i2ul(&to->unsigned33)); + assert(i2ul(&ti->unsigned42) == i2ul(&to->unsigned42)); + + xer_fprint(stderr, &asn_DEF_T, ti); + xer_fprint(stderr, &asn_DEF_T, to); +} + +static void +NO_encode(int testNo, T_t *ti) { + asn_enc_rval_t er; + unsigned char buf[16]; + + fprintf(stderr, "%d IN: { %lu, %lu }\n", testNo, + i2ul(&ti->unsigned33), i2ul(&ti->unsigned42)); + + er = uper_encode_to_buffer(&asn_DEF_T, ti, buf, sizeof buf); + assert(er.encoded == -1); +} + +int main() { + T_t ti; + + memset(&ti, 0, sizeof(ti)); + ul2i(&ti.unsigned33, 0); + ul2i(&ti.unsigned42, 0); + verify(1, &ti); + + ul2i(&ti.unsigned33, 1); + ul2i(&ti.unsigned42, 1); + verify(2, &ti); + + ul2i(&ti.unsigned33, 5000000000); + ul2i(&ti.unsigned42, 3153600000000); + verify(3, &ti); + + ul2i(&ti.unsigned33, -1); + ul2i(&ti.unsigned42, 0); + NO_encode(4, &ti); + + ul2i(&ti.unsigned33, 0); + ul2i(&ti.unsigned42, -1); + NO_encode(5, &ti); + + ul2i(&ti.unsigned33, 5000000000 + 1); + ul2i(&ti.unsigned42, 0); + NO_encode(6, &ti); + + ul2i(&ti.unsigned33, 0); + ul2i(&ti.unsigned42, 3153600000000 + 1); + NO_encode(7, &ti); + + ul2i(&ti.unsigned33, 5000000000 - 1); + ul2i(&ti.unsigned42, 3153600000000 - 1); + verify(8, &ti); + + return 0; +} + +#endif /* 64-bit platform */ |