9. Communicate with your Pico over RPC#

Now, let’s revisit pw_console and pw_rpc. This time, we’ll send commands to and view logs from the real Pico device.

Interact with the Pico#

  1. Fire up a pw_console instance that’s connected to the Pico:

    In Bazel Build Targets right-click :rp2040_console (native_binary) (under //apps/blinky) and then select Run target.

    bazelisk run //apps/blinky:rp2040_console
    
    bazelisk run //apps/blinky:rp2350_console
    

    If you see a selection prompt like the one below, select Debug Probe (CMSIS-DAP) - CDC-ACM UART Interface.

    Please select a serial port device.
    Available ports:
      1 - /dev/ttyACM0 - Raspberry Pi - Debug Probe (CMSIS-DAP) - CDC-ACM UART Interface
      2 - /dev/ttyACM1 - Raspberry Pi - Pico - Board CDC
      3 - /dev/ttyS0 - None - n/a
      4 - /dev/ttyS1 - None - n/a
      5 - /dev/ttyS2 - None - n/a
      6 - /dev/ttyS3 - None - n/a
    
  2. Toggle the Pico’s LED by typing the following into Python Repl and then pressing Enter:

    >>> device.rpcs.blinky.Blinky.ToggleLed()
    

    You should see your Raspberry Pi Pico’s LED turn either on or off. If you run the command again you should see the LED switch to its opposite state.

    (The next few commands should also be executed in the Python Repl, just like the last one.)

  3. Blink the LED 10 times:

    >>> device.rpcs.blinky.Blinky.Blink(interval_ms=1000, blink_count=10)
    
  4. Write some custom automation in the Python REPL to achieve the same blinking effect:

    >>> def my_blinky(count, delay):
    ...     from time import sleep
    ...     toggle = device.rpcs.blinky.Blinky.ToggleLed
    ...     for _ in range(count):
    ...         toggle()
    ...         sleep(delay)
    ...
    >>> my_blinky(20, 1)
    

    Note

    The REPL doesn’t currently support top-level execution of multiple statements. You can workaround this by wrapping your multi-statement logic in a function and then invoking the function, as seen in my_blinky().

  5. View your board’s onboard temperature:

    >>> device.rpcs.board.Board.OnboardTemp()
    

    In Python Results (top-left pane) you should see output like this:

    >>> device.rpcs.board.Board.OnboardTemp()
    (Status.OK, board.rpc.OnboardTempResponse(temp=23.861492156982422))
    

    Put your finger on the microprocessor in the middle of your Pico (the black square with a raspberry logo etched on it) for a few seconds and then run the temperature command again and you should see the temperature increase.

    Exercise

    Can you figure out the code to read the temperature 10 times with a 1-second interval between readings, and then output the average temperature? See Temperature averaging solution for one solution.

  6. Leave the console open and proceed to the next section.

Search and filter logs#

You can search and filter your device’s logs. Try it now:

  1. Click anywhere in the Device Logs table (top-right pane) to focus that part of the UI.

  2. Press / to search the logs.

  3. Type ON and press Enter. A log that matches that string should be highlighted.

  4. Press n to go to next match and N to go to previous match.

  5. Press Ctrl+Alt+F to filter out logs that don’t match your query.

  6. Press Ctrl+Alt+R or click Clear Filters to clear your filter and return to the original table view.

Keep pw_console running#

There’s no need to close pw_console right now. You’re going to use it on the next page.

Summary#

On this page we revisited our old friends pw_console and pw_rpc, except this time we used them to communicate with a real embedded device rather than a simulated device running on our development host. In other words, when it’s time to switch from simulated devices to real ones, you don’t need to learn new tools.

Next, head over to 10. Automate common workflows to learn how to package up common development tasks into small scripts so that your whole team can benefit from them.

Appendix#

Temperature averaging solution#

Here’s one possible solution to the temperature averaging exercise at the bottom of Interact with the Pico.

def average(count, delay):
    from time import sleep
    total = 0
    sample = device.rpcs.board.Board.OnboardTemp
    for _ in range(count):
        status, data = sample()
        total += data.temp
        sleep(delay)
    return total / count

average(10, 1)