17. Extract the Nibble from an 8-bit Register

Write a C program to extract a nibble (4-bit value) from an 8-bit register.

  • The user provides an 8-bit integer (register value) and a nibble position (0 for lower nibble, 1 for upper nibble).
  • Your task is to extract and print the nibble’s decimal value.

Input Format

  • An 8-bit integer (0-255) representing the register value.
  • A nibble position (0 for lower, 1 for upper).

Output Format

  • The extracted 4-bit value (0-15).

 

Example-1

Input: reg = 0xAB, pos = 0
Output: 11
(0xAB → lower nibble = 0xB = 11)

Example-2

Input: reg = 0xAB, pos = 1
Output: 10
(0xAB → upper nibble = 0xA = 10)

Example-3

Input: reg = 0xFF, pos = 0
Output: 15

 

 

 

Need Help? Refer to the Quick Guide below

In embedded systems, a single register often contains multiple fields, each controlling a different function. These fields are packed into specific bit positions.

Example: A 16-bit Control Register

BitsField Name
15 – 12Mode
11 – 8Speed
7 – 0Flags

To work with them, we need two core skills:

  1. Extracting a field (reading the bits at a specific position)
  2. Replacing or updating that field (without touching other bits)
     

This is done using bit masking and bit shifting.

To extract Speed field (bits 8 to 11):

uint16_t speed = (reg >> 8) & 0x0F;

To update the Mode field (bits 12 to 15):

reg &= ~(0x0F << 12);         // Clear Mode bits
reg |= ((new_mode & 0x0F) << 12); // Set new Mode

Key Operations

Extract a bit field

value = (reg >> position) & mask;

Replace a bit field

/* Where mask is a binary mask for the number of bits in the field.
E.g., For 3-bit field → mask = 0x07 */


reg &= ~(mask << position);            // Clear the bits (mask= high bits)
reg |= ((new_value & mask) << position); // Set the new bits

Relevance in Embedded/Firmware

  • Most hardware registers (UART, Timer, ADC, SPI) use bit fields to define different parameters.
  • Peripheral setup often involves:
    • Extracting status bits (e.g., data ready, error)
    • Modifying specific bits (e.g., set baud rate, enable TX)
  • It’s unsafe to overwrite the entire register — instead, we update only the target bits.

This is why precise extraction and modification using bit masks is a core embedded skill.