pyb — functions related to the board

The pyb module contains specific functions related to the board.

Miscellaneous functions

pyb.have_cdc()

Return True if USB is connected as a serial device, False otherwise.

Note

This function is deprecated. Use pyb.USB_VCP().isconnected() instead.

pyb.hid((buttons, x, y, z))

Takes a 4-tuple (or list) and sends it to the USB host (the PC) to signal a HID mouse-motion event.

Note

This function is deprecated. Use pyb.USB_HID.send() instead.

pyb.info([dump_alloc_table])

Print out lots of information about the board.

pyb.main(filename)

Set the filename of the main script to run after boot.py is finished. If this function is not called then the default file main.py will be executed.

It only makes sense to call this function from within boot.py.

pyb.mount(device, mountpoint, *, readonly=False, mkfs=False)

Mount a block device and make it available as part of the filesystem. device must be an object that provides the block protocol:

  • readblocks(self, blocknum, buf)
  • writeblocks(self, blocknum, buf) (optional)
  • count(self)
  • sync(self) (optional)

readblocks and writeblocks should copy data between buf and the block device, starting from block number blocknum on the device. buf will be a bytearray with length a multiple of 512. If writeblocks is not defined then the device is mounted read-only. The return value of these two functions is ignored.

count should return the number of blocks available on the device. sync, if implemented, should sync the data on the device.

The parameter mountpoint is the location in the root of the filesystem to mount the device. It must begin with a forward-slash.

If readonly is True, then the device is mounted read-only, otherwise it is mounted read-write.

If mkfs is True, then a new filesystem is created if one does not already exist.

To unmount a device, pass None as the device and the mount location as mountpoint.

pyb.repl_uart(uart)

Get or set the UART object where the REPL is repeated on.

pyb.rng()

Return a 30-bit hardware generated random number.

pyb.sync()

Sync all file systems.

pyb.unique_id()

Returns a string of 12 bytes (96 bits), which is the unique ID of the MCU.

pyb.usb_mode([modestr, ]vid=0xf055, pid=0x9801, hid=pyb.hid_mouse)

If called with no arguments, return the current USB mode as a string.

If called with modestr provided, attempts to set USB mode. This can only be done when called from boot.py before pyb.main() has been called. The following values of modestr are understood:

  • None: disables USB
  • 'VCP': enable with VCP (Virtual COM Port) interface
  • 'MSC': enable with MSC (mass storage device class) interface
  • 'VCP+MSC': enable with VCP and MSC
  • 'VCP+HID': enable with VCP and HID (human interface device)

For backwards compatibility, 'CDC' is understood to mean 'VCP' (and similarly for 'CDC+MSC' and 'CDC+HID').

The vid and pid parameters allow you to specify the VID (vendor id) and PID (product id).

If enabling HID mode, you may also specify the HID details by passing the hid keyword parameter. It takes a tuple of (subclass, protocol, max packet length, polling interval, report descriptor). By default it will set appropriate values for a USB mouse. There is also a pyb.hid_keyboard constant, which is an appropriate tuple for a USB keyboard.