Browse Source

features: fix endian.

Closes: https://github.com/lightningnetwork/lightning-rfc/issues/424

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
ppa-0.6.1
Rusty Russell 7 years ago
committed by Christian Decker
parent
commit
149e967ba3
  1. 28
      common/features.c

28
common/features.c

@ -10,11 +10,28 @@ static const u32 local_features[] = {
static const u32 global_features[] = { static const u32 global_features[] = {
}; };
/* BOLT #1:
*
* All data fields are unsigned big-endian unless otherwise specified.
*/
static void set_bit(u8 **ptr, u32 bit) static void set_bit(u8 **ptr, u32 bit)
{ {
if (bit / 8 >= tal_len(*ptr)) size_t len = tal_len(*ptr);
tal_resizez(ptr, (bit / 8) + 1); if (bit / 8 >= len) {
(*ptr)[bit / 8] |= (1 << (bit % 8)); size_t newlen = (bit / 8) + 1;
u8 *newarr = tal_arrz(tal_parent(*ptr), u8, newlen);
memcpy(newarr + (newlen - len), *ptr, len);
tal_free(*ptr);
*ptr = newarr;
len = newlen;
}
(*ptr)[len - 1 - bit / 8] |= (1 << (bit % 8));
}
static bool test_bit(const u8 *features, size_t byte, unsigned int bit)
{
assert(byte < tal_len(features));
return features[tal_len(features) - 1 - byte] & (1 << (bit % 8));
} }
/* We don't insist on anything, it's all optional. */ /* We don't insist on anything, it's all optional. */
@ -37,11 +54,6 @@ u8 *get_offered_local_features(const tal_t *ctx)
return mkfeatures(ctx, local_features, ARRAY_SIZE(local_features)); return mkfeatures(ctx, local_features, ARRAY_SIZE(local_features));
} }
static bool test_bit(const u8 *features, size_t byte, unsigned int bit)
{
return features[byte] & (1 << (bit % 8));
}
static bool feature_set(const u8 *features, size_t bit) static bool feature_set(const u8 *features, size_t bit)
{ {
size_t bytenum = bit / 8; size_t bytenum = bit / 8;

Loading…
Cancel
Save