#![allow(non_snake_case, non_upper_case_globals)]
#![allow(non_camel_case_types)]
use crate::{RORegister, RWRegister};
#[cfg(not(feature = "nosync"))]
use core::marker::PhantomData;
pub mod CTRL {
pub mod RUN {
pub const offset: u32 = 0;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod DATA_FORMAT_24_BIT {
pub const offset: u32 = 1;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const ALL_24_BITS_VALID: u32 = 0b0;
pub const DROP_UPPER_2_BITS_PER_BYTE: u32 = 0b1;
}
}
pub mod DATA_FORMAT_18_BIT {
pub const offset: u32 = 2;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const LOWER_18_BITS_VALID: u32 = 0b0;
pub const UPPER_18_BITS_VALID: u32 = 0b1;
}
}
pub mod DATA_FORMAT_16_BIT {
pub const offset: u32 = 3;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod MASTER {
pub const offset: u32 = 5;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod ENABLE_PXP_HANDSHAKE {
pub const offset: u32 = 6;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod WORD_LENGTH {
pub const offset: u32 = 8;
pub const mask: u32 = 0b11 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const _16_BIT: u32 = 0b00;
pub const _8_BIT: u32 = 0b01;
pub const _18_BIT: u32 = 0b10;
pub const _24_BIT: u32 = 0b11;
}
}
pub mod LCD_DATABUS_WIDTH {
pub const offset: u32 = 10;
pub const mask: u32 = 0b11 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const _16_BIT: u32 = 0b00;
pub const _8_BIT: u32 = 0b01;
pub const _18_BIT: u32 = 0b10;
pub const _24_BIT: u32 = 0b11;
}
}
pub mod CSC_DATA_SWIZZLE {
pub const offset: u32 = 12;
pub const mask: u32 = 0b11 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const NO_SWAP: u32 = 0b00;
pub const BIG_ENDIAN_SWAP: u32 = 0b01;
pub const HWD_SWAP: u32 = 0b10;
pub const HWD_BYTE_SWAP: u32 = 0b11;
}
}
pub mod INPUT_DATA_SWIZZLE {
pub const offset: u32 = 14;
pub const mask: u32 = 0b11 << offset;
pub mod R {}
pub mod W {}
pub use super::CSC_DATA_SWIZZLE::RW;
}
pub mod DOTCLK_MODE {
pub const offset: u32 = 17;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod BYPASS_COUNT {
pub const offset: u32 = 19;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod SHIFT_NUM_BITS {
pub const offset: u32 = 21;
pub const mask: u32 = 0b11111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod DATA_SHIFT_DIR {
pub const offset: u32 = 26;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const TXDATA_SHIFT_LEFT: u32 = 0b0;
pub const TXDATA_SHIFT_RIGHT: u32 = 0b1;
}
}
pub mod CLKGATE {
pub const offset: u32 = 30;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod SFTRST {
pub const offset: u32 = 31;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod CTRL_SET {
pub use super::CTRL::BYPASS_COUNT;
pub use super::CTRL::CLKGATE;
pub use super::CTRL::CSC_DATA_SWIZZLE;
pub use super::CTRL::DATA_FORMAT_16_BIT;
pub use super::CTRL::DATA_FORMAT_18_BIT;
pub use super::CTRL::DATA_FORMAT_24_BIT;
pub use super::CTRL::DATA_SHIFT_DIR;
pub use super::CTRL::DOTCLK_MODE;
pub use super::CTRL::ENABLE_PXP_HANDSHAKE;
pub use super::CTRL::INPUT_DATA_SWIZZLE;
pub use super::CTRL::LCD_DATABUS_WIDTH;
pub use super::CTRL::MASTER;
pub use super::CTRL::RUN;
pub use super::CTRL::SFTRST;
pub use super::CTRL::SHIFT_NUM_BITS;
pub use super::CTRL::WORD_LENGTH;
}
pub mod CTRL_CLR {
pub use super::CTRL::BYPASS_COUNT;
pub use super::CTRL::CLKGATE;
pub use super::CTRL::CSC_DATA_SWIZZLE;
pub use super::CTRL::DATA_FORMAT_16_BIT;
pub use super::CTRL::DATA_FORMAT_18_BIT;
pub use super::CTRL::DATA_FORMAT_24_BIT;
pub use super::CTRL::DATA_SHIFT_DIR;
pub use super::CTRL::DOTCLK_MODE;
pub use super::CTRL::ENABLE_PXP_HANDSHAKE;
pub use super::CTRL::INPUT_DATA_SWIZZLE;
pub use super::CTRL::LCD_DATABUS_WIDTH;
pub use super::CTRL::MASTER;
pub use super::CTRL::RUN;
pub use super::CTRL::SFTRST;
pub use super::CTRL::SHIFT_NUM_BITS;
pub use super::CTRL::WORD_LENGTH;
}
pub mod CTRL_TOG {
pub use super::CTRL::BYPASS_COUNT;
pub use super::CTRL::CLKGATE;
pub use super::CTRL::CSC_DATA_SWIZZLE;
pub use super::CTRL::DATA_FORMAT_16_BIT;
pub use super::CTRL::DATA_FORMAT_18_BIT;
pub use super::CTRL::DATA_FORMAT_24_BIT;
pub use super::CTRL::DATA_SHIFT_DIR;
pub use super::CTRL::DOTCLK_MODE;
pub use super::CTRL::ENABLE_PXP_HANDSHAKE;
pub use super::CTRL::INPUT_DATA_SWIZZLE;
pub use super::CTRL::LCD_DATABUS_WIDTH;
pub use super::CTRL::MASTER;
pub use super::CTRL::RUN;
pub use super::CTRL::SFTRST;
pub use super::CTRL::SHIFT_NUM_BITS;
pub use super::CTRL::WORD_LENGTH;
}
pub mod CTRL1 {
pub mod VSYNC_EDGE_IRQ {
pub const offset: u32 = 8;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const NO_REQUEST: u32 = 0b0;
pub const REQUEST: u32 = 0b1;
}
}
pub mod CUR_FRAME_DONE_IRQ {
pub const offset: u32 = 9;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub use super::VSYNC_EDGE_IRQ::RW;
}
pub mod UNDERFLOW_IRQ {
pub const offset: u32 = 10;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub use super::VSYNC_EDGE_IRQ::RW;
}
pub mod OVERFLOW_IRQ {
pub const offset: u32 = 11;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub use super::VSYNC_EDGE_IRQ::RW;
}
pub mod VSYNC_EDGE_IRQ_EN {
pub const offset: u32 = 12;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod CUR_FRAME_DONE_IRQ_EN {
pub const offset: u32 = 13;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod UNDERFLOW_IRQ_EN {
pub const offset: u32 = 14;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod OVERFLOW_IRQ_EN {
pub const offset: u32 = 15;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod BYTE_PACKING_FORMAT {
pub const offset: u32 = 16;
pub const mask: u32 = 0b1111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod IRQ_ON_ALTERNATE_FIELDS {
pub const offset: u32 = 20;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod FIFO_CLEAR {
pub const offset: u32 = 21;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod START_INTERLACE_FROM_SECOND_FIELD {
pub const offset: u32 = 22;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod INTERLACE_FIELDS {
pub const offset: u32 = 23;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod RECOVER_ON_UNDERFLOW {
pub const offset: u32 = 24;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod BM_ERROR_IRQ {
pub const offset: u32 = 25;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub use super::VSYNC_EDGE_IRQ::RW;
}
pub mod BM_ERROR_IRQ_EN {
pub const offset: u32 = 26;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod CS_OUT_SELECT {
pub const offset: u32 = 30;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod IMAGE_DATA_SELECT {
pub const offset: u32 = 31;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod CTRL1_SET {
pub use super::CTRL1::BM_ERROR_IRQ;
pub use super::CTRL1::BM_ERROR_IRQ_EN;
pub use super::CTRL1::BYTE_PACKING_FORMAT;
pub use super::CTRL1::CS_OUT_SELECT;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ_EN;
pub use super::CTRL1::FIFO_CLEAR;
pub use super::CTRL1::IMAGE_DATA_SELECT;
pub use super::CTRL1::INTERLACE_FIELDS;
pub use super::CTRL1::IRQ_ON_ALTERNATE_FIELDS;
pub use super::CTRL1::OVERFLOW_IRQ;
pub use super::CTRL1::OVERFLOW_IRQ_EN;
pub use super::CTRL1::RECOVER_ON_UNDERFLOW;
pub use super::CTRL1::START_INTERLACE_FROM_SECOND_FIELD;
pub use super::CTRL1::UNDERFLOW_IRQ;
pub use super::CTRL1::UNDERFLOW_IRQ_EN;
pub use super::CTRL1::VSYNC_EDGE_IRQ;
pub use super::CTRL1::VSYNC_EDGE_IRQ_EN;
}
pub mod CTRL1_CLR {
pub use super::CTRL1::BM_ERROR_IRQ;
pub use super::CTRL1::BM_ERROR_IRQ_EN;
pub use super::CTRL1::BYTE_PACKING_FORMAT;
pub use super::CTRL1::CS_OUT_SELECT;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ_EN;
pub use super::CTRL1::FIFO_CLEAR;
pub use super::CTRL1::IMAGE_DATA_SELECT;
pub use super::CTRL1::INTERLACE_FIELDS;
pub use super::CTRL1::IRQ_ON_ALTERNATE_FIELDS;
pub use super::CTRL1::OVERFLOW_IRQ;
pub use super::CTRL1::OVERFLOW_IRQ_EN;
pub use super::CTRL1::RECOVER_ON_UNDERFLOW;
pub use super::CTRL1::START_INTERLACE_FROM_SECOND_FIELD;
pub use super::CTRL1::UNDERFLOW_IRQ;
pub use super::CTRL1::UNDERFLOW_IRQ_EN;
pub use super::CTRL1::VSYNC_EDGE_IRQ;
pub use super::CTRL1::VSYNC_EDGE_IRQ_EN;
}
pub mod CTRL1_TOG {
pub use super::CTRL1::BM_ERROR_IRQ;
pub use super::CTRL1::BM_ERROR_IRQ_EN;
pub use super::CTRL1::BYTE_PACKING_FORMAT;
pub use super::CTRL1::CS_OUT_SELECT;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ;
pub use super::CTRL1::CUR_FRAME_DONE_IRQ_EN;
pub use super::CTRL1::FIFO_CLEAR;
pub use super::CTRL1::IMAGE_DATA_SELECT;
pub use super::CTRL1::INTERLACE_FIELDS;
pub use super::CTRL1::IRQ_ON_ALTERNATE_FIELDS;
pub use super::CTRL1::OVERFLOW_IRQ;
pub use super::CTRL1::OVERFLOW_IRQ_EN;
pub use super::CTRL1::RECOVER_ON_UNDERFLOW;
pub use super::CTRL1::START_INTERLACE_FROM_SECOND_FIELD;
pub use super::CTRL1::UNDERFLOW_IRQ;
pub use super::CTRL1::UNDERFLOW_IRQ_EN;
pub use super::CTRL1::VSYNC_EDGE_IRQ;
pub use super::CTRL1::VSYNC_EDGE_IRQ_EN;
}
pub mod CTRL2 {
pub mod EVEN_LINE_PATTERN {
pub const offset: u32 = 12;
pub const mask: u32 = 0b111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const RGB: u32 = 0b000;
pub const RBG: u32 = 0b001;
pub const GBR: u32 = 0b010;
pub const GRB: u32 = 0b011;
pub const BRG: u32 = 0b100;
pub const BGR: u32 = 0b101;
}
}
pub mod ODD_LINE_PATTERN {
pub const offset: u32 = 16;
pub const mask: u32 = 0b111 << offset;
pub mod R {}
pub mod W {}
pub use super::EVEN_LINE_PATTERN::RW;
}
pub mod BURST_LEN_8 {
pub const offset: u32 = 20;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod OUTSTANDING_REQS {
pub const offset: u32 = 21;
pub const mask: u32 = 0b111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const REQ_1: u32 = 0b000;
pub const REQ_2: u32 = 0b001;
pub const REQ_4: u32 = 0b010;
pub const REQ_8: u32 = 0b011;
pub const REQ_16: u32 = 0b100;
}
}
}
pub mod CTRL2_SET {
pub use super::CTRL2::BURST_LEN_8;
pub use super::CTRL2::EVEN_LINE_PATTERN;
pub use super::CTRL2::ODD_LINE_PATTERN;
pub use super::CTRL2::OUTSTANDING_REQS;
}
pub mod CTRL2_CLR {
pub use super::CTRL2::BURST_LEN_8;
pub use super::CTRL2::EVEN_LINE_PATTERN;
pub use super::CTRL2::ODD_LINE_PATTERN;
pub use super::CTRL2::OUTSTANDING_REQS;
}
pub mod CTRL2_TOG {
pub use super::CTRL2::BURST_LEN_8;
pub use super::CTRL2::EVEN_LINE_PATTERN;
pub use super::CTRL2::ODD_LINE_PATTERN;
pub use super::CTRL2::OUTSTANDING_REQS;
}
pub mod TRANSFER_COUNT {
pub mod H_COUNT {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod V_COUNT {
pub const offset: u32 = 16;
pub const mask: u32 = 0xffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod CUR_BUF {
pub mod ADDR {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffffffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod NEXT_BUF {
pub use super::CUR_BUF::ADDR;
}
pub mod VDCTRL0 {
pub mod VSYNC_PULSE_WIDTH {
pub const offset: u32 = 0;
pub const mask: u32 = 0x3ffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod HALF_LINE_MODE {
pub const offset: u32 = 18;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod HALF_LINE {
pub const offset: u32 = 19;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod VSYNC_PULSE_WIDTH_UNIT {
pub const offset: u32 = 20;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod VSYNC_PERIOD_UNIT {
pub const offset: u32 = 21;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod ENABLE_POL {
pub const offset: u32 = 24;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod DOTCLK_POL {
pub const offset: u32 = 25;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod HSYNC_POL {
pub const offset: u32 = 26;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod VSYNC_POL {
pub const offset: u32 = 27;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod ENABLE_PRESENT {
pub const offset: u32 = 28;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod VDCTRL0_SET {
pub use super::VDCTRL0::DOTCLK_POL;
pub use super::VDCTRL0::ENABLE_POL;
pub use super::VDCTRL0::ENABLE_PRESENT;
pub use super::VDCTRL0::HALF_LINE;
pub use super::VDCTRL0::HALF_LINE_MODE;
pub use super::VDCTRL0::HSYNC_POL;
pub use super::VDCTRL0::VSYNC_PERIOD_UNIT;
pub use super::VDCTRL0::VSYNC_POL;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH_UNIT;
}
pub mod VDCTRL0_CLR {
pub use super::VDCTRL0::DOTCLK_POL;
pub use super::VDCTRL0::ENABLE_POL;
pub use super::VDCTRL0::ENABLE_PRESENT;
pub use super::VDCTRL0::HALF_LINE;
pub use super::VDCTRL0::HALF_LINE_MODE;
pub use super::VDCTRL0::HSYNC_POL;
pub use super::VDCTRL0::VSYNC_PERIOD_UNIT;
pub use super::VDCTRL0::VSYNC_POL;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH_UNIT;
}
pub mod VDCTRL0_TOG {
pub use super::VDCTRL0::DOTCLK_POL;
pub use super::VDCTRL0::ENABLE_POL;
pub use super::VDCTRL0::ENABLE_PRESENT;
pub use super::VDCTRL0::HALF_LINE;
pub use super::VDCTRL0::HALF_LINE_MODE;
pub use super::VDCTRL0::HSYNC_POL;
pub use super::VDCTRL0::VSYNC_PERIOD_UNIT;
pub use super::VDCTRL0::VSYNC_POL;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH;
pub use super::VDCTRL0::VSYNC_PULSE_WIDTH_UNIT;
}
pub mod VDCTRL1 {
pub mod VSYNC_PERIOD {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffffffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod VDCTRL2 {
pub mod HSYNC_PERIOD {
pub const offset: u32 = 0;
pub const mask: u32 = 0x3ffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod HSYNC_PULSE_WIDTH {
pub const offset: u32 = 18;
pub const mask: u32 = 0x3fff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod VDCTRL3 {
pub mod VERTICAL_WAIT_CNT {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod HORIZONTAL_WAIT_CNT {
pub const offset: u32 = 16;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod VSYNC_ONLY {
pub const offset: u32 = 28;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod MUX_SYNC_SIGNALS {
pub const offset: u32 = 29;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod VDCTRL4 {
pub mod DOTCLK_H_VALID_DATA_CNT {
pub const offset: u32 = 0;
pub const mask: u32 = 0x3ffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod SYNC_SIGNALS_ON {
pub const offset: u32 = 18;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod DOTCLK_DLY_SEL {
pub const offset: u32 = 29;
pub const mask: u32 = 0b111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod BM_ERROR_STAT {
pub use super::CUR_BUF::ADDR;
}
pub mod CRC_STAT {
pub mod CRC_VALUE {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffffffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod STAT {
pub mod LFIFO_COUNT {
pub const offset: u32 = 0;
pub const mask: u32 = 0x1ff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod TXFIFO_EMPTY {
pub const offset: u32 = 26;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod TXFIFO_FULL {
pub const offset: u32 = 27;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod LFIFO_EMPTY {
pub const offset: u32 = 28;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod LFIFO_FULL {
pub const offset: u32 = 29;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod DMA_REQ {
pub const offset: u32 = 30;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod PRESENT {
pub const offset: u32 = 31;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod THRES {
pub mod PANIC {
pub const offset: u32 = 0;
pub const mask: u32 = 0x1ff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod FASTCLOCK {
pub const offset: u32 = 16;
pub const mask: u32 = 0x1ff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod PIGEONCTRL0 {
pub mod FD_PERIOD {
pub const offset: u32 = 0;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod LD_PERIOD {
pub const offset: u32 = 16;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod PIGEONCTRL0_SET {
pub use super::PIGEONCTRL0::FD_PERIOD;
pub use super::PIGEONCTRL0::LD_PERIOD;
}
pub mod PIGEONCTRL0_CLR {
pub use super::PIGEONCTRL0::FD_PERIOD;
pub use super::PIGEONCTRL0::LD_PERIOD;
}
pub mod PIGEONCTRL0_TOG {
pub use super::PIGEONCTRL0::FD_PERIOD;
pub use super::PIGEONCTRL0::LD_PERIOD;
}
pub mod PIGEONCTRL1 {
pub mod FRAME_CNT_PERIOD {
pub const offset: u32 = 0;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod FRAME_CNT_CYCLES {
pub const offset: u32 = 16;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod PIGEONCTRL1_SET {
pub use super::PIGEONCTRL1::FRAME_CNT_CYCLES;
pub use super::PIGEONCTRL1::FRAME_CNT_PERIOD;
}
pub mod PIGEONCTRL1_CLR {
pub use super::PIGEONCTRL1::FRAME_CNT_CYCLES;
pub use super::PIGEONCTRL1::FRAME_CNT_PERIOD;
}
pub mod PIGEONCTRL1_TOG {
pub use super::PIGEONCTRL1::FRAME_CNT_CYCLES;
pub use super::PIGEONCTRL1::FRAME_CNT_PERIOD;
}
pub mod PIGEONCTRL2 {
pub mod PIGEON_DATA_EN {
pub const offset: u32 = 0;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod PIGEON_CLK_GATE {
pub const offset: u32 = 1;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod PIGEONCTRL2_SET {
pub use super::PIGEONCTRL2::PIGEON_CLK_GATE;
pub use super::PIGEONCTRL2::PIGEON_DATA_EN;
}
pub mod PIGEONCTRL2_CLR {
pub use super::PIGEONCTRL2::PIGEON_CLK_GATE;
pub use super::PIGEONCTRL2::PIGEON_DATA_EN;
}
pub mod PIGEONCTRL2_TOG {
pub use super::PIGEONCTRL2::PIGEON_CLK_GATE;
pub use super::PIGEONCTRL2::PIGEON_DATA_EN;
}
pub mod PIGEON_0_0 {
pub mod EN {
pub const offset: u32 = 0;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod POL {
pub const offset: u32 = 1;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const ACTIVE_HIGH: u32 = 0b0;
pub const ACTIVE_LOW: u32 = 0b1;
}
}
pub mod INC_SEL {
pub const offset: u32 = 2;
pub const mask: u32 = 0b11 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const PCLK: u32 = 0b00;
pub const LINE: u32 = 0b01;
pub const FRAME: u32 = 0b10;
pub const SIG_ANOTHER: u32 = 0b11;
}
}
pub mod OFFSET {
pub const offset: u32 = 4;
pub const mask: u32 = 0b1111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod MASK_CNT_SEL {
pub const offset: u32 = 8;
pub const mask: u32 = 0b1111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const HSTATE_CNT: u32 = 0b0000;
pub const HSTATE_CYCLE: u32 = 0b0001;
pub const VSTATE_CNT: u32 = 0b0010;
pub const VSTATE_CYCLE: u32 = 0b0011;
pub const FRAME_CNT: u32 = 0b0100;
pub const FRAME_CYCLE: u32 = 0b0101;
pub const HCNT: u32 = 0b0110;
pub const VCNT: u32 = 0b0111;
}
}
pub mod MASK_CNT {
pub const offset: u32 = 12;
pub const mask: u32 = 0xfff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
pub mod STATE_MASK {
pub const offset: u32 = 24;
pub const mask: u32 = 0xff << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const FS: u32 = 0b00000001;
pub const FB: u32 = 0b00000010;
pub const FD: u32 = 0b00000100;
pub const FE: u32 = 0b00001000;
pub const LS: u32 = 0b00010000;
pub const LB: u32 = 0b00100000;
pub const LD: u32 = 0b01000000;
pub const LE: u32 = 0b10000000;
}
}
}
pub mod PIGEON_0_1 {
pub mod SET_CNT {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const START_ACTIVE: u32 = 0b0000000000000000;
}
}
pub mod CLR_CNT {
pub const offset: u32 = 16;
pub const mask: u32 = 0xffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const CLEAR_USING_MASK: u32 = 0b0000000000000000;
}
}
}
pub mod PIGEON_0_2 {
pub mod SIG_LOGIC {
pub const offset: u32 = 0;
pub const mask: u32 = 0b1111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const DIS: u32 = 0b0000;
pub const AND: u32 = 0b0001;
pub const OR: u32 = 0b0010;
pub const MASK: u32 = 0b0011;
}
}
pub mod SIG_ANOTHER {
pub const offset: u32 = 4;
pub const mask: u32 = 0b11111 << offset;
pub mod R {}
pub mod W {}
pub mod RW {
pub const CLEAR_USING_MASK: u32 = 0b00000;
}
}
}
pub mod PIGEON_1_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_1_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_1_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_2_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_2_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_2_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_3_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_3_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_3_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_4_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_4_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_4_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_5_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_5_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_5_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_6_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_6_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_6_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_7_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_7_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_7_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_8_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_8_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_8_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_9_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_9_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_9_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_10_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_10_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_10_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod PIGEON_11_0 {
pub use super::PIGEON_0_0::EN;
pub use super::PIGEON_0_0::INC_SEL;
pub use super::PIGEON_0_0::MASK_CNT;
pub use super::PIGEON_0_0::MASK_CNT_SEL;
pub use super::PIGEON_0_0::OFFSET;
pub use super::PIGEON_0_0::POL;
pub use super::PIGEON_0_0::STATE_MASK;
}
pub mod PIGEON_11_1 {
pub use super::PIGEON_0_1::CLR_CNT;
pub use super::PIGEON_0_1::SET_CNT;
}
pub mod PIGEON_11_2 {
pub use super::PIGEON_0_2::SIG_ANOTHER;
pub use super::PIGEON_0_2::SIG_LOGIC;
}
pub mod LUT_CTRL {
pub mod LUT_BYPASS {
pub const offset: u32 = 0;
pub const mask: u32 = 1 << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod LUT0_ADDR {
pub mod ADDR {
pub const offset: u32 = 0;
pub const mask: u32 = 0xff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod LUT0_DATA {
pub mod DATA {
pub const offset: u32 = 0;
pub const mask: u32 = 0xffffffff << offset;
pub mod R {}
pub mod W {}
pub mod RW {}
}
}
pub mod LUT1_ADDR {
pub use super::LUT0_ADDR::ADDR;
}
pub mod LUT1_DATA {
pub use super::LUT0_DATA::DATA;
}
#[repr(C)]
pub struct RegisterBlock {
pub CTRL: RWRegister<u32>,
pub CTRL_SET: RWRegister<u32>,
pub CTRL_CLR: RWRegister<u32>,
pub CTRL_TOG: RWRegister<u32>,
pub CTRL1: RWRegister<u32>,
pub CTRL1_SET: RWRegister<u32>,
pub CTRL1_CLR: RWRegister<u32>,
pub CTRL1_TOG: RWRegister<u32>,
pub CTRL2: RWRegister<u32>,
pub CTRL2_SET: RWRegister<u32>,
pub CTRL2_CLR: RWRegister<u32>,
pub CTRL2_TOG: RWRegister<u32>,
pub TRANSFER_COUNT: RWRegister<u32>,
_reserved1: [u32; 3],
pub CUR_BUF: RWRegister<u32>,
_reserved2: [u32; 3],
pub NEXT_BUF: RWRegister<u32>,
_reserved3: [u32; 7],
pub VDCTRL0: RWRegister<u32>,
pub VDCTRL0_SET: RWRegister<u32>,
pub VDCTRL0_CLR: RWRegister<u32>,
pub VDCTRL0_TOG: RWRegister<u32>,
pub VDCTRL1: RWRegister<u32>,
_reserved4: [u32; 3],
pub VDCTRL2: RWRegister<u32>,
_reserved5: [u32; 3],
pub VDCTRL3: RWRegister<u32>,
_reserved6: [u32; 3],
pub VDCTRL4: RWRegister<u32>,
_reserved7: [u32; 55],
pub BM_ERROR_STAT: RWRegister<u32>,
_reserved8: [u32; 3],
pub CRC_STAT: RWRegister<u32>,
_reserved9: [u32; 3],
pub STAT: RORegister<u32>,
_reserved10: [u32; 19],
pub THRES: RWRegister<u32>,
_reserved11: [u32; 95],
pub PIGEONCTRL0: RWRegister<u32>,
pub PIGEONCTRL0_SET: RWRegister<u32>,
pub PIGEONCTRL0_CLR: RWRegister<u32>,
pub PIGEONCTRL0_TOG: RWRegister<u32>,
pub PIGEONCTRL1: RWRegister<u32>,
pub PIGEONCTRL1_SET: RWRegister<u32>,
pub PIGEONCTRL1_CLR: RWRegister<u32>,
pub PIGEONCTRL1_TOG: RWRegister<u32>,
pub PIGEONCTRL2: RWRegister<u32>,
pub PIGEONCTRL2_SET: RWRegister<u32>,
pub PIGEONCTRL2_CLR: RWRegister<u32>,
pub PIGEONCTRL2_TOG: RWRegister<u32>,
_reserved12: [u32; 276],
pub PIGEON_0_0: RWRegister<u32>,
_reserved13: [u32; 3],
pub PIGEON_0_1: RWRegister<u32>,
_reserved14: [u32; 3],
pub PIGEON_0_2: RWRegister<u32>,
_reserved15: [u32; 7],
pub PIGEON_1_0: RWRegister<u32>,
_reserved16: [u32; 3],
pub PIGEON_1_1: RWRegister<u32>,
_reserved17: [u32; 3],
pub PIGEON_1_2: RWRegister<u32>,
_reserved18: [u32; 7],
pub PIGEON_2_0: RWRegister<u32>,
_reserved19: [u32; 3],
pub PIGEON_2_1: RWRegister<u32>,
_reserved20: [u32; 3],
pub PIGEON_2_2: RWRegister<u32>,
_reserved21: [u32; 7],
pub PIGEON_3_0: RWRegister<u32>,
_reserved22: [u32; 3],
pub PIGEON_3_1: RWRegister<u32>,
_reserved23: [u32; 3],
pub PIGEON_3_2: RWRegister<u32>,
_reserved24: [u32; 7],
pub PIGEON_4_0: RWRegister<u32>,
_reserved25: [u32; 3],
pub PIGEON_4_1: RWRegister<u32>,
_reserved26: [u32; 3],
pub PIGEON_4_2: RWRegister<u32>,
_reserved27: [u32; 7],
pub PIGEON_5_0: RWRegister<u32>,
_reserved28: [u32; 3],
pub PIGEON_5_1: RWRegister<u32>,
_reserved29: [u32; 3],
pub PIGEON_5_2: RWRegister<u32>,
_reserved30: [u32; 7],
pub PIGEON_6_0: RWRegister<u32>,
_reserved31: [u32; 3],
pub PIGEON_6_1: RWRegister<u32>,
_reserved32: [u32; 3],
pub PIGEON_6_2: RWRegister<u32>,
_reserved33: [u32; 7],
pub PIGEON_7_0: RWRegister<u32>,
_reserved34: [u32; 3],
pub PIGEON_7_1: RWRegister<u32>,
_reserved35: [u32; 3],
pub PIGEON_7_2: RWRegister<u32>,
_reserved36: [u32; 7],
pub PIGEON_8_0: RWRegister<u32>,
_reserved37: [u32; 3],
pub PIGEON_8_1: RWRegister<u32>,
_reserved38: [u32; 3],
pub PIGEON_8_2: RWRegister<u32>,
_reserved39: [u32; 7],
pub PIGEON_9_0: RWRegister<u32>,
_reserved40: [u32; 3],
pub PIGEON_9_1: RWRegister<u32>,
_reserved41: [u32; 3],
pub PIGEON_9_2: RWRegister<u32>,
_reserved42: [u32; 7],
pub PIGEON_10_0: RWRegister<u32>,
_reserved43: [u32; 3],
pub PIGEON_10_1: RWRegister<u32>,
_reserved44: [u32; 3],
pub PIGEON_10_2: RWRegister<u32>,
_reserved45: [u32; 7],
pub PIGEON_11_0: RWRegister<u32>,
_reserved46: [u32; 3],
pub PIGEON_11_1: RWRegister<u32>,
_reserved47: [u32; 3],
pub PIGEON_11_2: RWRegister<u32>,
_reserved48: [u32; 7],
pub LUT_CTRL: RWRegister<u32>,
_reserved49: [u32; 3],
pub LUT0_ADDR: RWRegister<u32>,
_reserved50: [u32; 3],
pub LUT0_DATA: RWRegister<u32>,
_reserved51: [u32; 3],
pub LUT1_ADDR: RWRegister<u32>,
_reserved52: [u32; 3],
pub LUT1_DATA: RWRegister<u32>,
}
pub struct ResetValues {
pub CTRL: u32,
pub CTRL_SET: u32,
pub CTRL_CLR: u32,
pub CTRL_TOG: u32,
pub CTRL1: u32,
pub CTRL1_SET: u32,
pub CTRL1_CLR: u32,
pub CTRL1_TOG: u32,
pub CTRL2: u32,
pub CTRL2_SET: u32,
pub CTRL2_CLR: u32,
pub CTRL2_TOG: u32,
pub TRANSFER_COUNT: u32,
pub CUR_BUF: u32,
pub NEXT_BUF: u32,
pub VDCTRL0: u32,
pub VDCTRL0_SET: u32,
pub VDCTRL0_CLR: u32,
pub VDCTRL0_TOG: u32,
pub VDCTRL1: u32,
pub VDCTRL2: u32,
pub VDCTRL3: u32,
pub VDCTRL4: u32,
pub BM_ERROR_STAT: u32,
pub CRC_STAT: u32,
pub STAT: u32,
pub THRES: u32,
pub PIGEONCTRL0: u32,
pub PIGEONCTRL0_SET: u32,
pub PIGEONCTRL0_CLR: u32,
pub PIGEONCTRL0_TOG: u32,
pub PIGEONCTRL1: u32,
pub PIGEONCTRL1_SET: u32,
pub PIGEONCTRL1_CLR: u32,
pub PIGEONCTRL1_TOG: u32,
pub PIGEONCTRL2: u32,
pub PIGEONCTRL2_SET: u32,
pub PIGEONCTRL2_CLR: u32,
pub PIGEONCTRL2_TOG: u32,
pub PIGEON_0_0: u32,
pub PIGEON_0_1: u32,
pub PIGEON_0_2: u32,
pub PIGEON_1_0: u32,
pub PIGEON_1_1: u32,
pub PIGEON_1_2: u32,
pub PIGEON_2_0: u32,
pub PIGEON_2_1: u32,
pub PIGEON_2_2: u32,
pub PIGEON_3_0: u32,
pub PIGEON_3_1: u32,
pub PIGEON_3_2: u32,
pub PIGEON_4_0: u32,
pub PIGEON_4_1: u32,
pub PIGEON_4_2: u32,
pub PIGEON_5_0: u32,
pub PIGEON_5_1: u32,
pub PIGEON_5_2: u32,
pub PIGEON_6_0: u32,
pub PIGEON_6_1: u32,
pub PIGEON_6_2: u32,
pub PIGEON_7_0: u32,
pub PIGEON_7_1: u32,
pub PIGEON_7_2: u32,
pub PIGEON_8_0: u32,
pub PIGEON_8_1: u32,
pub PIGEON_8_2: u32,
pub PIGEON_9_0: u32,
pub PIGEON_9_1: u32,
pub PIGEON_9_2: u32,
pub PIGEON_10_0: u32,
pub PIGEON_10_1: u32,
pub PIGEON_10_2: u32,
pub PIGEON_11_0: u32,
pub PIGEON_11_1: u32,
pub PIGEON_11_2: u32,
pub LUT_CTRL: u32,
pub LUT0_ADDR: u32,
pub LUT0_DATA: u32,
pub LUT1_ADDR: u32,
pub LUT1_DATA: u32,
}
#[cfg(not(feature = "nosync"))]
pub struct Instance {
pub(crate) addr: u32,
pub(crate) _marker: PhantomData<*const RegisterBlock>,
}
#[cfg(not(feature = "nosync"))]
impl ::core::ops::Deref for Instance {
type Target = RegisterBlock;
#[inline(always)]
fn deref(&self) -> &RegisterBlock {
unsafe { &*(self.addr as *const _) }
}
}
#[cfg(feature = "rtfm")]
unsafe impl Send for Instance {}
pub mod LCDIF {
use super::ResetValues;
#[cfg(not(feature = "nosync"))]
use super::Instance;
#[cfg(not(feature = "nosync"))]
const INSTANCE: Instance = Instance {
addr: 0x402b8000,
_marker: ::core::marker::PhantomData,
};
pub const reset: ResetValues = ResetValues {
CTRL: 0xC0000000,
CTRL_SET: 0xC0000000,
CTRL_CLR: 0xC0000000,
CTRL_TOG: 0xC0000000,
CTRL1: 0x000F0000,
CTRL1_SET: 0x000F0000,
CTRL1_CLR: 0x000F0000,
CTRL1_TOG: 0x000F0000,
CTRL2: 0x00200000,
CTRL2_SET: 0x00200000,
CTRL2_CLR: 0x00200000,
CTRL2_TOG: 0x00200000,
TRANSFER_COUNT: 0x00010000,
CUR_BUF: 0x00000000,
NEXT_BUF: 0x00000000,
VDCTRL0: 0x00000000,
VDCTRL0_SET: 0x00000000,
VDCTRL0_CLR: 0x00000000,
VDCTRL0_TOG: 0x00000000,
VDCTRL1: 0x00000000,
VDCTRL2: 0x00000000,
VDCTRL3: 0x00000000,
VDCTRL4: 0x00000000,
BM_ERROR_STAT: 0x00000000,
CRC_STAT: 0x00000000,
STAT: 0x95000000,
THRES: 0x0100000F,
PIGEONCTRL0: 0x00000000,
PIGEONCTRL0_SET: 0x00000000,
PIGEONCTRL0_CLR: 0x00000000,
PIGEONCTRL0_TOG: 0x00000000,
PIGEONCTRL1: 0x00000000,
PIGEONCTRL1_SET: 0x00000000,
PIGEONCTRL1_CLR: 0x00000000,
PIGEONCTRL1_TOG: 0x00000000,
PIGEONCTRL2: 0x00000000,
PIGEONCTRL2_SET: 0x00000000,
PIGEONCTRL2_CLR: 0x00000000,
PIGEONCTRL2_TOG: 0x00000000,
PIGEON_0_0: 0x00000000,
PIGEON_0_1: 0x00000000,
PIGEON_0_2: 0x00000000,
PIGEON_1_0: 0x00000000,
PIGEON_1_1: 0x00000000,
PIGEON_1_2: 0x00000000,
PIGEON_2_0: 0x00000000,
PIGEON_2_1: 0x00000000,
PIGEON_2_2: 0x00000000,
PIGEON_3_0: 0x00000000,
PIGEON_3_1: 0x00000000,
PIGEON_3_2: 0x00000000,
PIGEON_4_0: 0x00000000,
PIGEON_4_1: 0x00000000,
PIGEON_4_2: 0x00000000,
PIGEON_5_0: 0x00000000,
PIGEON_5_1: 0x00000000,
PIGEON_5_2: 0x00000000,
PIGEON_6_0: 0x00000000,
PIGEON_6_1: 0x00000000,
PIGEON_6_2: 0x00000000,
PIGEON_7_0: 0x00000000,
PIGEON_7_1: 0x00000000,
PIGEON_7_2: 0x00000000,
PIGEON_8_0: 0x00000000,
PIGEON_8_1: 0x00000000,
PIGEON_8_2: 0x00000000,
PIGEON_9_0: 0x00000000,
PIGEON_9_1: 0x00000000,
PIGEON_9_2: 0x00000000,
PIGEON_10_0: 0x00000000,
PIGEON_10_1: 0x00000000,
PIGEON_10_2: 0x00000000,
PIGEON_11_0: 0x00000000,
PIGEON_11_1: 0x00000000,
PIGEON_11_2: 0x00000000,
LUT_CTRL: 0x00000001,
LUT0_ADDR: 0x00000000,
LUT0_DATA: 0x00000000,
LUT1_ADDR: 0x00000000,
LUT1_DATA: 0x00000000,
};
#[cfg(not(feature = "nosync"))]
#[allow(renamed_and_removed_lints)]
#[allow(private_no_mangle_statics)]
#[no_mangle]
static mut LCDIF_TAKEN: bool = false;
#[cfg(not(feature = "nosync"))]
#[inline]
pub fn take() -> Option<Instance> {
external_cortex_m::interrupt::free(|_| unsafe {
if LCDIF_TAKEN {
None
} else {
LCDIF_TAKEN = true;
Some(INSTANCE)
}
})
}
#[cfg(not(feature = "nosync"))]
#[inline]
pub fn release(inst: Instance) {
external_cortex_m::interrupt::free(|_| unsafe {
if LCDIF_TAKEN && inst.addr == INSTANCE.addr {
LCDIF_TAKEN = false;
} else {
panic!("Released a peripheral which was not taken");
}
});
}
#[cfg(not(feature = "nosync"))]
#[inline]
pub unsafe fn steal() -> Instance {
LCDIF_TAKEN = true;
INSTANCE
}
}
pub const LCDIF: *const RegisterBlock = 0x402b8000 as *const _;