code size benchmark: separate morph function to avoid overhead from scanf/printf

This commit is contained in:
Michael Sippel 2025-02-14 13:51:59 +01:00
parent 959d2f9185
commit eb29fad4b2
Signed by: senvas
GPG key ID: F96CF119C34B64A6
3 changed files with 56 additions and 74 deletions

View file

@ -3,12 +3,11 @@
#include <morphisms/length-prefix.h>
#include <morphisms/posint.h>
int main() {
uint8_t bufA[1024];
uint8_t bufB[1024];
scanf("%s", bufA);
__attribute__((noinline))
int morph_posint_radix(
uint8_t * bufA,
uint8_t * bufB
) {
// morph to
// ~ <PosInt 10 BigEndian> ~ [~<LengthPrefix x86.UInt64> <Digit 10> ~ Char ~ Ascii]
{
@ -23,40 +22,14 @@ int main() {
struct LengthPrefixUInt8Array * src = (void*) bufB;
struct LengthPrefixUInt64Array * dst = (void*) bufA;
length_prefix_array_map_8_to_64( morph_digit_as_char_to_uint64, src, dst );
/*
dst->len = src->len;
for( uint64_t i = 0; i < src->len; ++i )
morph_digit_as_char_to_uint64( &src->items[i], &dst->items[i] );
*/
}
// morph to
// ~ <PosInt 10 LittleEndian> ~ [~<LengthPrefix x86.UInt64> <Digit 10> ~ _10 ~ x86.UInt64]
{
uint64_t const radix = 10;
struct LengthPrefixUInt64Array * src = (void*) bufA;
struct LengthPrefixUInt64Array * dst = (void*) bufB;
morph_posint_endianness( radix, src, dst );
}
// morph to
// ~ <PosInt 16 LittleEndian> ~ [~<LengthPrefix x86.UInt64> <Digit 16> ~ _16 ~ x86.UInt64]
{
uint64_t const src_radix = 10;
uint64_t const dst_radix = 16;
struct LengthPrefixUInt64Array * src = (void*) bufB;
struct LengthPrefixUInt64Array * dst = (void*) bufA;
morph_posint_radix( src_radix, dst_radix, src, dst );
}
// morph to
// ~ <PosInt 16 LittleEndian> ~ [~<LengthPrefix x86.UInt64> <Digit 10> ~ _10 ~ x86.UInt64]
{
uint64_t const radix = 16;
struct LengthPrefixUInt64Array * src = (void*) bufA;
struct LengthPrefixUInt64Array * dst = (void*) bufB;
morph_posint_endianness( radix, src, dst );
morph_posint_radix_little( src_radix, dst_radix, src, dst );
}
// morph to
@ -66,11 +39,6 @@ int main() {
struct LengthPrefixUInt8Array * dst = (void*) bufA;
length_prefix_array_map_64_to_8( morph_digit_as_uint64_to_char, src, dst );
/*
dst->len = src->len;
for( uint64_t i = 0; i < src->len; ++i )
morph_digit_as_uint64_to_char( &src->items[i], &dst->items[i] );
*/
}
// morph to
@ -81,6 +49,15 @@ int main() {
morph_string_as_length_prefix_to_nullterm( src, dst );
}
return 0;
}
int main() {
uint8_t bufA[1024];
uint8_t bufB[1024];
scanf("%s", bufA);
morph_posint_radix( bufA, bufB );
printf("%s\n", bufB);
return 0;