Search code examples
cbit-manipulationbit-shiftbitwise-andbitwise-or

How to insert a new Bit at MSB and ignoring all other bits


I found this: add a new bit to the left of byte and discard right bit of byte but:

x = 0x80000000 | (x >> 1);

doesn't seam what I'm looking for.

union {
  unsigned char byte_variable;
  // a structure with 8 single bit bit-field objects, overlapping the union member "byte"
  struct {
                unsigned b0: 1;
                unsigned b1: 1;
                unsigned b2: 1;
                unsigned b3: 1;
                unsigned b4: 1;
                unsigned b5: 1;
                unsigned b6: 1;
                unsigned b7: 1;
  };
} byte_8;

apparently setting a bit like this:

byte_8.b7 = 1;

doesn't work if you use a Union.

How to add a new bit at the MSB and disregarding or without altering all other bits in the variable.

byte_8.byte_variable;

Solution

  • The ordering of bitfields within a union is implementation defined, so what you tried isn't guaranteed to work.

    If you want to set the highest order bit in an unsigned char, just OR the variable with a value that has only that bit set:

    unsigned char x;
    // set x
    x = x | 0x80;