Program Listing for File IO_BANK0_GPIO21_CTRL_FUNCSEL.h#

Return to documentation for file (src/generated/enums/IO_BANK0_GPIO21_CTRL_FUNCSEL.h)

#pragma once

#include <cstdint>
#include <cstring>

namespace RP2040
{

enum class IO_BANK0_GPIO21_CTRL_FUNCSEL : uint8_t
{
    spi0_ss_n = 1,
    uart1_rx = 2,
    i2c0_scl = 3,
    pwm_b_2 = 4,
    sio_21 = 5,
    pio0_21 = 6,
    pio1_21 = 7,
    clocks_gpout_0 = 8,
    usb_muxing_overcurr_detect = 9,
    null = 31
};
static_assert(sizeof(IO_BANK0_GPIO21_CTRL_FUNCSEL) == 1);

inline const char *to_string(IO_BANK0_GPIO21_CTRL_FUNCSEL instance)
{
    const char *result = "UNKNOWN IO_BANK0_GPIO21_CTRL_FUNCSEL";

    switch (instance)
    {
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::spi0_ss_n:
        result = "spi0_ss_n";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::uart1_rx:
        result = "uart1_rx";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::i2c0_scl:
        result = "i2c0_scl";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::pwm_b_2:
        result = "pwm_b_2";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::sio_21:
        result = "sio_21";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::pio0_21:
        result = "pio0_21";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::pio1_21:
        result = "pio1_21";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::clocks_gpout_0:
        result = "clocks_gpout_0";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::usb_muxing_overcurr_detect:
        result = "usb_muxing_overcurr_detect";
        break;
    case IO_BANK0_GPIO21_CTRL_FUNCSEL::null:
        result = "null";
        break;
    }

    return result;
}

inline bool from_string(const char *data, IO_BANK0_GPIO21_CTRL_FUNCSEL &output)
{
    bool result = false;

    if ((result = !strncmp(data, "spi0_ss_n", 9)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::spi0_ss_n;
    }
    else if ((result = !strncmp(data, "uart1_rx", 8)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::uart1_rx;
    }
    else if ((result = !strncmp(data, "i2c0_scl", 8)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::i2c0_scl;
    }
    else if ((result = !strncmp(data, "pwm_b_2", 7)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::pwm_b_2;
    }
    else if ((result = !strncmp(data, "sio_21", 6)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::sio_21;
    }
    else if ((result = !strncmp(data, "pio0_21", 7)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::pio0_21;
    }
    else if ((result = !strncmp(data, "pio1_21", 7)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::pio1_21;
    }
    else if ((result = !strncmp(data, "clocks_gpout_0", 14)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::clocks_gpout_0;
    }
    else if ((result = !strncmp(data, "usb_muxing_overcurr_detect", 26)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::usb_muxing_overcurr_detect;
    }
    else if ((result = !strncmp(data, "null", 4)))
    {
        output = IO_BANK0_GPIO21_CTRL_FUNCSEL::null;
    }

    return result;
}

}; // namespace RP2040