Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

rp2xxx: Add support for assembling RP2350-specific PIO #320

Merged
merged 31 commits into from
Jan 17, 2025

Conversation

Grazfather
Copy link
Contributor

@Grazfather Grazfather commented Dec 19, 2024

RP2350 adds the following new instruction features:

  • Adds PINCTRL_JMP_PIN as a source for the WAIT instruction, plus an offset in the range 0-3.
    • This gives WAIT pin arguments a per-SM mapping that is independent of the IN-mapped pins.
  • Adds PINDIRS as a destination for MOV.
    • This allows changing the direction of all OUT-mapped pins with a single instruction: MOV PINDIRS, NULL or MOV
      PINDIRS, ~NULL
  • [ ] Adds SM IRQ flags as a source for MOV x, STATUS
    • This allows branching (as well as blocking) on the assertion of SM IRQ flags.
  • Extends IRQ instruction encoding to allow state machines to set, clear and observe IRQ flags from different PIO
    blocks.
    • There is no delay penalty for cross-PIO IRQ flags: an IRQ on one state machine is observable to all state
      machines on the next cycle.
  • Adds the FJOIN_RX_GET FIFO mode.
    • A new MOV encoding reads any of the four RX FIFO storage registers into OSR.
    • This instruction permits random reads of the four FIFO entries, indexed either by instruction bits or the Y
      scratch register.
  • Adds the FJOIN_RX_PUT FIFO mode.
    • A new MOV encoding writes the ISR into any of the four RX FIFO storage registers.
    • The registers are indexed either by instruction bits or the Y scratch register.
      RP2350 adds the following security features:
  • Limits Non-secure PIOs (set to via ACCESSCTRL) to observation of only Non-secure GPIOs. Attempting to read a
    Secure GPIO returns a 0.
  • Disables cross-PIO functionality (IRQs, CTRL_NEXTPREV operations) between Non-secure PIO blocks (those which
    permit Non-secure access according to ACCESSCTRL) and Secure-only blocks (those which do not).
    RP2350 includes the following general improvements:
  • Increased the number of PIO blocks from two to three (8 → 12 state machines).
  • Improved GPIO input/output delay and skew.
  • Reduced DMA request (DREQ) latency by one cycle vs RP2040

@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch 3 times, most recently from 6355e52 to 648c840 Compare December 20, 2024 20:29
@Grazfather Grazfather changed the title rp2xxx: Add support for rp2350 assembling rp2xxx: Add support for assembling RP2350-specific PIO Dec 20, 2024
@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch from 8b02d19 to 4852d4b Compare January 6, 2025 17:13
We currently depend on this stuff being comptime, would have to manage
the memory if we wanted to support it running at runtime

This reverts commit dc3b857.
@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch from f3c9a4d to a2900f0 Compare January 16, 2025 00:34
@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch from a2900f0 to e807673 Compare January 16, 2025 00:36
@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch from 2e28677 to 3349843 Compare January 16, 2025 01:01
@Grazfather Grazfather force-pushed the rp2350_pio_assembler branch from 3349843 to 9186848 Compare January 16, 2025 01:16
@Grazfather Grazfather marked this pull request as ready for review January 16, 2025 01:27
@mattnite
Copy link
Contributor

@Grazfather there's one item unchecked, I take it you forgot to check it?

@Grazfather
Copy link
Contributor Author

@mattnite I don't understand that one. I don't see any difference in the encoding of the (plain) mov instruction in https://datasheets.raspberrypi.com/rp2350/rp2350-datasheet.pdf (page 893).

@mattnite mattnite merged commit eccecc2 into ZigEmbeddedGroup:main Jan 17, 2025
11 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants