4.18.5.12 I/O Lines Programming Example

The programming example shown in the following table is used to obtain the following configuration:

  • 4-bit output port on I/O lines 0 to 3 (should be written in a single write operation), open-drain, with pullup resistor
  • Four output signals on I/O lines 4 to 7 (to drive LEDs for example), driven high and low, no pullup resistor, no pulldown resistor
  • Four input signals on I/O lines 8 to 11 (to read push-button states for example), with pullup resistors, glitch filters and input change interrupts
  • Four input signals on I/O line 12 to 15 to read an external device status (polled, thus no input change interrupt), no pullup resistor, no glitch filter
  • I/O lines 16 to 19 assigned to peripheral A functions with pullup resistor
  • I/O lines 20 to 23 assigned to peripheral B functions with pulldown resistor
  • I/O lines 24 to 27 assigned to peripheral C with input change interrupt, no pullup resistor and no pulldown resistor
  • I/O lines 28 to 31 assigned to peripheral D, no pullup resistor and no pulldown resistor
    Table 4-9. Programming Example
    RegisterValue to be Written
    PIO_PER0x0000_FFFF
    PIO_PDR0xFFFF_0000
    PIO_OER0x0000_00FF
    PIO_ODR0xFFFF_FF00
    PIO_IFER0x0000_0F00
    PIO_IFDR0xFFFF_F0FF
    PIO_SODR0x0000_0000
    PIO_CODR0x0FFF_FFFF
    PIO_IER0x0F00_0F00
    PIO_IDR0xF0FF_F0FF
    PIO_MDER0x0000_000F
    PIO_MDDR0xFFFF_FFF0
    PIO_PUDR0xFFF0_00F0
    PIO_PUER0x000F_FF0F
    PIO_PPDDR0xFF0F_FFFF
    PIO_PPDER0x00F0_0000
    PIO_ABCDSR10xF0F0_0000
    PIO_ABCDSR20xFF00_0000
    PIO_OWER0x0000_000F
    PIO_OWDR0x0FFF_FFF0