mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-26 08:15:54 +00:00 
			
		
		
		
	Import code from previous AssetBuilder version
This commit is contained in:
		
							
								
								
									
										108
									
								
								thirdparty/libtomcrypt/pk/asn1/der/set/der_encode_set.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										108
									
								
								thirdparty/libtomcrypt/pk/asn1/der/set/der_encode_set.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,108 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file der_encode_set.c | ||||
|   ASN.1 DER, Encode a SET, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_DER | ||||
|  | ||||
| /* LTC define to ASN.1 TAG */ | ||||
| static int _ltc_to_asn1(ltc_asn1_type v) | ||||
| { | ||||
|    switch (v) { | ||||
|       case LTC_ASN1_BOOLEAN:                 return 0x01; | ||||
|       case LTC_ASN1_INTEGER: | ||||
|       case LTC_ASN1_SHORT_INTEGER:           return 0x02; | ||||
|       case LTC_ASN1_RAW_BIT_STRING: | ||||
|       case LTC_ASN1_BIT_STRING:              return 0x03; | ||||
|       case LTC_ASN1_OCTET_STRING:            return 0x04; | ||||
|       case LTC_ASN1_NULL:                    return 0x05; | ||||
|       case LTC_ASN1_OBJECT_IDENTIFIER:       return 0x06; | ||||
|       case LTC_ASN1_UTF8_STRING:             return 0x0C; | ||||
|       case LTC_ASN1_PRINTABLE_STRING:        return 0x13; | ||||
|       case LTC_ASN1_TELETEX_STRING:          return 0x14; | ||||
|       case LTC_ASN1_IA5_STRING:              return 0x16; | ||||
|       case LTC_ASN1_UTCTIME:                 return 0x17; | ||||
|       case LTC_ASN1_GENERALIZEDTIME:         return 0x18; | ||||
|       case LTC_ASN1_SEQUENCE:                return 0x30; | ||||
|       case LTC_ASN1_SET: | ||||
|       case LTC_ASN1_SETOF:                   return 0x31; | ||||
|       case LTC_ASN1_CHOICE: | ||||
|       case LTC_ASN1_CONSTRUCTED: | ||||
|       case LTC_ASN1_CONTEXT_SPECIFIC: | ||||
|       case LTC_ASN1_EOL:                     return -1; | ||||
|    } | ||||
|    return -1; | ||||
| } | ||||
|  | ||||
|  | ||||
| static int _qsort_helper(const void *a, const void *b) | ||||
| { | ||||
|    ltc_asn1_list *A = (ltc_asn1_list *)a, *B = (ltc_asn1_list *)b; | ||||
|    int            r; | ||||
|  | ||||
|    r = _ltc_to_asn1(A->type) - _ltc_to_asn1(B->type); | ||||
|  | ||||
|    /* for QSORT the order is UNDEFINED if they are "equal" which means it is NOT DETERMINISTIC.  So we force it to be :-) */ | ||||
|    if (r == 0) { | ||||
|       /* their order in the original list now determines the position */ | ||||
|       return A->used - B->used; | ||||
|    } else { | ||||
|       return r; | ||||
|    } | ||||
| } | ||||
|  | ||||
| /* | ||||
|    Encode a SET type | ||||
|    @param list      The list of items to encode | ||||
|    @param inlen     The number of items in the list | ||||
|    @param out       [out] The destination | ||||
|    @param outlen    [in/out] The size of the output | ||||
|    @return CRYPT_OK on success | ||||
| */ | ||||
| int der_encode_set(ltc_asn1_list *list, unsigned long inlen, | ||||
|                    unsigned char *out,  unsigned long *outlen) | ||||
| { | ||||
|    ltc_asn1_list  *copy; | ||||
|    unsigned long   x; | ||||
|    int             err; | ||||
|  | ||||
|    /* make copy of list */ | ||||
|    copy = XCALLOC(inlen, sizeof(*copy)); | ||||
|    if (copy == NULL) { | ||||
|       return CRYPT_MEM; | ||||
|    } | ||||
|  | ||||
|    /* fill in used member with index so we can fully sort it */ | ||||
|    for (x = 0; x < inlen; x++) { | ||||
|        copy[x]      = list[x]; | ||||
|        copy[x].used = x; | ||||
|    } | ||||
|  | ||||
|    /* sort it by the "type" field */ | ||||
|    XQSORT(copy, inlen, sizeof(*copy), &_qsort_helper); | ||||
|  | ||||
|    /* call der_encode_sequence_ex() */ | ||||
|    err = der_encode_sequence_ex(copy, inlen, out, outlen, LTC_ASN1_SET); | ||||
|  | ||||
|    /* free list */ | ||||
|    XFREE(copy); | ||||
|  | ||||
|    return err; | ||||
| } | ||||
|  | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										161
									
								
								thirdparty/libtomcrypt/pk/asn1/der/set/der_encode_setof.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										161
									
								
								thirdparty/libtomcrypt/pk/asn1/der/set/der_encode_setof.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,161 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file der_encode_setof.c | ||||
|   ASN.1 DER, Encode SET OF, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_DER | ||||
|  | ||||
| struct edge { | ||||
|    unsigned char *start; | ||||
|    unsigned long  size; | ||||
| }; | ||||
|  | ||||
| static int _qsort_helper(const void *a, const void *b) | ||||
| { | ||||
|    struct edge   *A = (struct edge *)a, *B = (struct edge *)b; | ||||
|    int            r; | ||||
|    unsigned long  x; | ||||
|  | ||||
|    /* compare min length */ | ||||
|    r = XMEMCMP(A->start, B->start, MIN(A->size, B->size)); | ||||
|  | ||||
|    if (r == 0 && A->size != B->size) { | ||||
|       if (A->size > B->size) { | ||||
|          for (x = B->size; x < A->size; x++) { | ||||
|             if (A->start[x]) { | ||||
|                return 1; | ||||
|             } | ||||
|          } | ||||
|       } else { | ||||
|          for (x = A->size; x < B->size; x++) { | ||||
|             if (B->start[x]) { | ||||
|                return -1; | ||||
|             } | ||||
|          } | ||||
|       } | ||||
|    } | ||||
|  | ||||
|    return r; | ||||
| } | ||||
|  | ||||
| /** | ||||
|    Encode a SETOF stucture | ||||
|    @param list      The list of items to encode | ||||
|    @param inlen     The number of items in the list | ||||
|    @param out       [out] The destination | ||||
|    @param outlen    [in/out] The size of the output | ||||
|    @return CRYPT_OK on success | ||||
| */ | ||||
| int der_encode_setof(ltc_asn1_list *list, unsigned long inlen, | ||||
|                      unsigned char *out,  unsigned long *outlen) | ||||
| { | ||||
|    unsigned long  x, y, z; | ||||
|    ptrdiff_t hdrlen; | ||||
|    int            err; | ||||
|    struct edge   *edges; | ||||
|    unsigned char *ptr, *buf; | ||||
|  | ||||
|    /* check that they're all the same type */ | ||||
|    for (x = 1; x < inlen; x++) { | ||||
|       if (list[x].type != list[x-1].type) { | ||||
|          return CRYPT_INVALID_ARG; | ||||
|       } | ||||
|    } | ||||
|  | ||||
|    /* alloc buffer to store copy of output */ | ||||
|    buf = XCALLOC(1, *outlen); | ||||
|    if (buf == NULL) { | ||||
|       return CRYPT_MEM; | ||||
|    } | ||||
|  | ||||
|    /* encode list */ | ||||
|    if ((err = der_encode_sequence_ex(list, inlen, buf, outlen, LTC_ASN1_SETOF)) != CRYPT_OK) { | ||||
|        XFREE(buf); | ||||
|        return err; | ||||
|    } | ||||
|  | ||||
|    /* allocate edges */ | ||||
|    edges = XCALLOC(inlen, sizeof(*edges)); | ||||
|    if (edges == NULL) { | ||||
|       XFREE(buf); | ||||
|       return CRYPT_MEM; | ||||
|    } | ||||
|  | ||||
|    /* skip header */ | ||||
|    ptr = buf + 1; | ||||
|  | ||||
|    /* now skip length data */ | ||||
|    x = *ptr++; | ||||
|    if (x >= 0x80) { | ||||
|       ptr += (x & 0x7F); | ||||
|    } | ||||
|  | ||||
|    /* get the size of the static header */ | ||||
|    hdrlen = ptr - buf; | ||||
|  | ||||
|  | ||||
|    /* scan for edges */ | ||||
|    x = 0; | ||||
|    while (ptr < (buf + *outlen)) { | ||||
|       /* store start */ | ||||
|       edges[x].start = ptr; | ||||
|  | ||||
|       /* skip type */ | ||||
|       z = 1; | ||||
|  | ||||
|       /* parse length */ | ||||
|       y = ptr[z++]; | ||||
|       if (y < 128) { | ||||
|          edges[x].size = y; | ||||
|       } else { | ||||
|          y &= 0x7F; | ||||
|          edges[x].size = 0; | ||||
|          while (y--) { | ||||
|             edges[x].size = (edges[x].size << 8) | ((unsigned long)ptr[z++]); | ||||
|          } | ||||
|       } | ||||
|  | ||||
|       /* skip content */ | ||||
|       edges[x].size += z; | ||||
|       ptr           += edges[x].size; | ||||
|       ++x; | ||||
|    } | ||||
|  | ||||
|    /* sort based on contents (using edges) */ | ||||
|    XQSORT(edges, inlen, sizeof(*edges), &_qsort_helper); | ||||
|  | ||||
|    /* copy static header */ | ||||
|    XMEMCPY(out, buf, hdrlen); | ||||
|  | ||||
|    /* copy+sort using edges+indecies to output from buffer */ | ||||
|    for (y = (unsigned long)hdrlen, x = 0; x < inlen; x++) { | ||||
|       XMEMCPY(out+y, edges[x].start, edges[x].size); | ||||
|       y += edges[x].size; | ||||
|    } | ||||
|  | ||||
| #ifdef LTC_CLEAN_STACK | ||||
|    zeromem(buf, *outlen); | ||||
| #endif | ||||
|  | ||||
|    /* free buffers */ | ||||
|    XFREE(edges); | ||||
|    XFREE(buf); | ||||
|  | ||||
|    return CRYPT_OK; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
		Reference in New Issue
	
	Block a user