Files
PiDoorbell/.vscode/Pico-W-Stub/rp2.pyi
2023-11-24 23:32:43 +01:00

133 lines
4.1 KiB
Python

"""
Functionality specific to the RP2.
MicroPython module: https://docs.micropython.org/en/v1.21.0/library/rp2.html
The ``rp2`` module contains functions and classes specific to the RP2040, as
used in the Raspberry Pi Pico.
See the `RP2040 Python datasheet
<https://datasheets.raspberrypi.com/pico/raspberry-pi-pico-python-sdk.pdf>`_
for more information, and `pico-micropython-examples
<https://github.com/raspberrypi/pico-micropython-examples/tree/master/pio>`_
for example code.
"""
from _rp2 import *
from _typeshed import Incomplete
_PROG_DATA: Incomplete
_PROG_OFFSET_PIO0: Incomplete
_PROG_OFFSET_PIO1: Incomplete
_PROG_EXECCTRL: Incomplete
_PROG_SHIFTCTRL: Incomplete
_PROG_OUT_PINS: Incomplete
_PROG_SET_PINS: Incomplete
_PROG_SIDESET_PINS: Incomplete
_PROG_MAX_FIELDS: Incomplete
class PIOASMError(Exception): ...
class PIOASMEmit:
labels: Incomplete
prog: Incomplete
wrap_used: bool
sideset_count: int
def __init__(
self,
*,
out_init: Incomplete | None = ...,
set_init: Incomplete | None = ...,
sideset_init: Incomplete | None = ...,
in_shiftdir: int = ...,
out_shiftdir: int = ...,
autopush: bool = ...,
autopull: bool = ...,
push_thresh: int = ...,
pull_thresh: int = ...,
fifo_join: int = ...,
) -> None: ...
delay_max: int
sideset_opt: Incomplete
pass_: Incomplete
num_instr: int
num_sideset: int
def start_pass(self, pass_) -> None: ...
def __getitem__(self, key): ...
def delay(self, delay): ...
def side(self, value): ...
def wrap_target(self) -> None: ...
def wrap(self) -> None: ...
def label(self, label) -> None: ...
def word(self, instr, label: Incomplete | None = ...): ...
def nop(self): ...
def jmp(self, cond, label: Incomplete | None = ...): ...
def wait(self, polarity, src, index): ...
def in_(self, src, data): ...
def out(self, dest, data): ...
def push(self, value: int = ..., value2: int = ...): ...
def pull(self, value: int = ..., value2: int = ...): ...
def mov(self, dest, src): ...
def irq(self, mod, index: Incomplete | None = ...): ...
def set(self, dest, data): ...
_pio_funcs: Incomplete
def asm_pio(
*,
out_init=None,
set_init=None,
sideset_init=None,
in_shiftdir=0,
out_shiftdir=0,
autopush=False,
autopull=False,
push_thresh=32,
pull_thresh=32,
fifo_join=PIO.JOIN_NONE,
) -> Incomplete:
"""
Assemble a PIO program.
The following parameters control the initial state of the GPIO pins, as one
of `PIO.IN_LOW`, `PIO.IN_HIGH`, `PIO.OUT_LOW` or `PIO.OUT_HIGH`. If the
program uses more than one pin, provide a tuple, e.g.
``out_init=(PIO.OUT_LOW, PIO.OUT_LOW)``.
- *out_init* configures the pins used for ``out()`` instructions.
- *set_init* configures the pins used for ``set()`` instructions. There can
be at most 5.
- *sideset_init* configures the pins used side-setting. There can be at
most 5.
The following parameters are used by default, but can be overridden in
`StateMachine.init()`:
- *in_shiftdir* is the default direction the ISR will shift, either
`PIO.SHIFT_LEFT` or `PIO.SHIFT_RIGHT`.
- *out_shiftdir* is the default direction the OSR will shift, either
`PIO.SHIFT_LEFT` or `PIO.SHIFT_RIGHT`.
- *push_thresh* is the threshold in bits before auto-push or conditional
re-pushing is triggered.
- *pull_thresh* is the threshold in bits before auto-pull or conditional
re-pulling is triggered.
The remaining parameters are:
- *autopush* configures whether auto-push is enabled.
- *autopull* configures whether auto-pull is enabled.
- *fifo_join* configures whether the 4-word TX and RX FIFOs should be
combined into a single 8-word FIFO for one direction only. The options
are `PIO.JOIN_NONE`, `PIO.JOIN_RX` and `PIO.JOIN_TX`.
"""
...
def asm_pio_encode(instr, sideset_count, sideset_opt=False) -> Incomplete:
"""
Assemble a single PIO instruction. You usually want to use `asm_pio()`
instead.
>>> rp2.asm_pio_encode("set(0, 1)", 0)
57345
"""
...