Skip to content

Commit

Permalink
docs:add duo pinpong examples
Browse files Browse the repository at this point in the history
  • Loading branch information
Rjgawuie committed Oct 24, 2024
1 parent b49c840 commit 4d3aee9
Show file tree
Hide file tree
Showing 2 changed files with 551 additions and 36 deletions.
296 changes: 277 additions & 19 deletions docs/duo/application-development/pinpong.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ The pinpong library is an open-source python library that is based on the firmat

## Pin numbers

### Duo

<div className='gpio_style'>

| pinpong | PIN NAME | Pin# | Pin# | PIN NAME | pinpong |
Expand Down Expand Up @@ -50,34 +52,44 @@ Please refer to the instructions: [pinmux](https://milkv.io/docs/duo/application

### Onboard LED blinking

This is an example of making the Duo onboard LED blink. You can create a new `blink.py` file directly in Duo, or create it on your computer and then upload it to Duo via ssh.
This is an example to blink the Duo's onboard LED. You can create a new file `blink.py` directly in Duo, or create it on your computer and upload it to Duo via SSH.

:::tip
The Pin number of the LED is 25. If you use other pins to connect external LEDs, please refer to the table above for the Pin number.
The Duo LED pin number is 25. If you use other pins to connect an external LED, please refer to the table above for the number.
:::

Contents of the `blink.py` file:
Contents of the file `blink.py` :

```python
# -*- coding: utf-8 -*-

# 实验效果:控制 MilkV-Duo 板载 LED 灯一秒闪烁一次。
# Function: Control the MilkV-Duo onboard LED light to flash once per second.
# 接线:使用电脑连接一块 MilkV-Duo 主控板。
# Wiring: Use a computer to connect a MilkV-Duo board.

# 在启动程序前请使用 duo-pinmux 确认引脚复用在正确的功能上。
# Please use duo-pinmux to confirm that the pins are multiplexed to the correct functions before starting the program.

import time
from pinpong.board import Board,Pin

Board("MILKV-DUO").begin()
Board("MILKV-DUO").begin() # 初始化,选择板型,不输入板型则进行自动识别;Initialize, select the board type, if you do not enter the board type, it will be automatically identified.

led = Pin(Pin.D25, Pin.OUT)
led = Pin(Pin.D14, Pin.OUT) # 引脚初始化为电平输出;The pin is initialized as output.

while True:
led.value(1)
led.value(1) # 输出高电平;Output High.
print("1")
time.sleep(1)
time.sleep(1) # 等待1秒 保持状态;Stay 1s.

led.value(0)
led.value(0) # 输出低电平;Output Low.
print("0")
time.sleep(1)
time.sleep(1) # 等待1秒 保持状态;Stay 1s.
```

Execute the `python blink.py` command in Duo's terminal:
Execute the command `python blink.py` in the Duo terminal:

```
[root@milkv-duo]~# python blink.py
milkv-duo
Expand All @@ -96,20 +108,266 @@ milkv-duo
1
0
```
You will see the LED blinking at 1 second intervals.

**Note**:
To test the `blink.py` example, which involves LED blinking, you need to disable the script responsible for the automatic LED blinking on the default firmware of Duo. In the Duo terminal, execute the following command:
```
You will see the LED flashing at 1 second intervals.

:::warning
The default firmware of the current Duo will automatically blink the LED after power-on. This is achieved by the boot script. When testing the blink example, you need to disable the LED blinking script. Execute in the Duo terminal:

```bash
mv /mnt/system/blink.sh /mnt/system/blink.sh_backup && sync
reboot
```
This command renames the LED blinking script. After restarting Duo, the LED will no longer blink.

Once you have finished testing the `blink.py`, if you want to restore the LED blinking script, you can rename it back using the following command and then restart Duo:
```
After testing the blink program, if you need to restore the LED blinking script, execute the following command:

```bash
mv /mnt/system/blink.sh_backup /mnt/system/blink.sh && sync
reboot
```
:::

### External button

This is an example of an external button. The program will read the GPIO status every 0.1s and print it to the screen. Please create a ```button.py``` file in Duo or upload it using SSH.

Contents of the file ```button.py```:

```python
# -*- coding: utf-8 -*-

# 实验效果:终端输出 MilkV-Duo 上的引脚电平。
# Function: The terminal outputs the pin level on MilkV-Duo.
# 接线:使用电脑连接一块 MilkV-Duo 主控板,主控板 D0 接一个按钮模块。
# Wiring: Connect MilkV-Duo board to computer, and connect the board D0 to a button module.

# 在启动程序前请使用 duo-pinmux 确认引脚复用在正确的功能上。
# Please use duo-pinmux to confirm that the pins are multiplexed to the correct functions before starting the program.

import time
from pinpong.board import Board,Pin

Board("MILKV-DUO").begin() # 初始化,选择板型,不输入板型则进行自动识别;Initialize, select the board type, if you do not enter the board type, it will be automatically identified.

btn = Pin(Pin.D0, Pin.IN) # 引脚初始化为电平输入;The pin is initialized as Input.

while T rue:
v = btn.value() # 读取引脚电平;Read pin level.
print(v) # 终端打印读取的电平状态;Print pin level.
time.sleep(0.1)
```

Connect a button module to the GP0 on Duo and execute the `python button.py` command in the Duo's terminal:

```
[root@milkv-duo]~# python ./button.py
milkv-duo
__________________________________________
| ____ _ ____ |
| / __ \(_)___ / __ \____ ____ ____ _ |
| / /_/ / / __ \/ /_/ / __ \/ __ \/ __ `/ |
| / ____/ / / / / ____/ /_/ / / / / /_/ / |
|/_/ /_/_/ /_/_/ \____/_/ /_/\__, / |
| v0.5.2 Designed by DFRobot /____/ |
|__________________________________________|
1
1
1
1
```

You can observe that the GPIO status is output on the screen every 0.1s, and you can also observe that the GPIO status is reversed by pressing the button.

### Software simulation external interrupt

This example demonstrates the use of the software simulated external interrupt function in the pinpong library. Please create or upload the ```irq.py``` file in Duo.

Contents of the file ```irq.py```:

```python
# -*- coding: utf-8 -*-

# 实验效果:引脚模拟中断功能测试。
# Function: Pin interrupt function test.
# 接线:使用电脑连接一块 MilkV-Duo 主控板,主控板 GP0 接一个按钮模块。
# Wiring: Connect a MilkV-Duo board, and connect the board GP0 to a button module.

# 在启动程序前请使用 duo-pinmux 确认引脚复用在正确的功能上。
# Please use duo-pinmux to confirm that the pins are multiplexed to the correct functions before starting the program.

import time
from pinpong.board import Board,Pin

Board("MILKV-DUO").begin() # 初始化,选择板型和端口号,不输入端口号则进行自动识别;Initialize, select the board type, if you do not enter the board type, it will be automatically identified.

btn = Pin(Pin.D0, Pin.IN)

def btn_rasing_handler(pin):# 中断事件回调函数;Interrupt event callback function.
print("\n--rising---")
print("pin = ", pin)

def btn_falling_handler(pin):# 中断事件回调函数;Interrupt event callback function.
print("\n--falling---")
print("pin = ", pin)

def btn_both_handler(pin):# 中断事件回调函数;Interrupt event callback function.
print("\n--both---")
print("pin = ", pin)

btn.irq(trigger=Pin.IRQ_FALLING, handler=btn_falling_handler) # 设置中断模式为下降沿触发;Set the interrupt mode to falling edge trigger.
#btn.irq(trigger=Pin.IRQ_RISING, handler=btn_rasing_handler) # 设置中断模式为上升沿触发,及回调函数;Set the interrupt mode to rising edge trigger and set callback function;
#btn.irq(trigger=Pin.IRQ_RISING+Pin.IRQ_FALLING, handler=btn_both_handler) # 设置中断模式为电平变化时触发;Set the interrupt mode to trigger when the level changes.

while True:
time.sleep(1)
```

Connect the button module to the Duo GP0 and execute ```python irq.py``` in the Duo terminal.

```
[root@milkv-duo]~# python ./irq.py
milkv-duo
__________________________________________
| ____ _ ____ |
| / __ \(_)___ / __ \____ ____ ____ _ |
| / /_/ / / __ \/ /_/ / __ \/ __ \/ __ `/ |
| / ____/ / / / / ____/ /_/ / / / / /_/ / |
|/_/ /_/_/ /_/_/ \____/_/ /_/\__, / |
| v0.5.2 Designed by DFRobot /____/ |
|__________________________________________|
--falling---
pin = 0
```

When the button is pressed, you will see the information printed on the screen after the falling edge event is triggered. You can also try different external interrupt event by turning on or off the comments of the ```btn.irq()``` function in the program.

## I2C

### Scan for devices on the bus

This example shows how to use pinpong to control the I2C on the Duo to scan for devices connected to the bus. Please create or upload the ```i2c_scan.py``` file in the Duo using SSH.

Contents of the file ```i2c_scan.py```:

```python
# -*- coding: utf-8 -*-

# 实验效果:控制 MilkV-Duo I2C 扫描 I2C 总线上的设备。
# Function: Control MilkV-Duo I2C to scan devices on the I2C bus.
# 接线:连接一个 I2C 从机设备到 MilkV-Duo 。
# Wiring: Connect an I2C slave device to MilkV-Duo.

# 在启动程序前请使用 duo-pinmux 确认引脚复用在正确的功能上。
# Please use duo-pinmux to confirm that the pins are multiplexed to the correct functions before starting the program.

import time
from pinpong.board import Board,I2C

Board("MILKV-DUO").begin() # 初始化,选择板型,不输入板型则进行自动识别;Initialize, select the board type, if you do not enter the board type, it will be automatically identified.
i2c = I2C(0) # 指定 I2C 设备号;Specifies the I2C device number.

l=i2c.scan() # 扫描 I2C 总线上的设备;;Scan for devices on the I2C bus.
print("i2c list:",l)

while(1):
time.sleep(1)
```

Connect the I2C device to I2C0 of Duo and execute ```python i2c_scan.py``` in the terminal.

```
[root@milkv-duo]~# python ./i2c_scan.py
milkv-duo
__________________________________________
| ____ _ ____ |
| / __ \(_)___ / __ \____ ____ ____ _ |
| / /_/ / / __ \/ /_/ / __ \/ __ \/ __ `/ |
| / ____/ / / / / ____/ /_/ / / / / /_/ / |
|/_/ /_/_/ /_/_/ \____/_/ /_/\__, / |
| v0.5.2 Designed by DFRobot /____/ |
|__________________________________________|
i2c list: [86]
```

After the program runs, the device address scanned by I2C will be printed on the screen.

### Communications

This example demonstrates how to use the pinpong library to send or read data over I2C. Please create or upload a ```i2c.py``` file on the Duo using SSH.

Contents of the file ```i2c.py```:

```python
# -*- coding: utf-8 -*-

# 实验效果:控制 MilkV-Duo I2C 通信协议展示。
# Function: Control MilkV-Duo I2C communication.
# 接线:连接一个 I2C 从机设备到 MilkV-Duo ,假设 I2C 地址为 0x33 。
# Wiring: Connect an I2C slave device to MilkV-Duo, assuming the I2C address is 0x33.

# 在启动程序前请使用 duo-pinmux 确认引脚复用在正确的功能上。
# Please use duo-pinmux to confirm that the pins are multiplexed to the correct functions before starting the program.

import time
from pinpong.board import Board,I2C

Board("MILKV-DUO").begin() # 初始化,选择板型和端口号,不输入端口号则进行自动识别;Initialize, select the board type, if you do not enter the board type, it will be automatically identified.

i2c = I2C(bus_num=3) # 设置使用的 I2C 号;Specifies the I2C device number.

l=i2c.scan() # 扫描 I2C 总线上的设备 - [0x33];Scan for devices on the I2C bus - [0x33].
print("i2c list:",l)

i2c.writeto(0x33,[1,2,3,4,5]) # 将 [1,2,3,4,5] 写入 I2C 设备;Write [1,2,3,4,5] to the I2C device.
i2c.readfrom(0x33,6) # 从 I2C 设备读取 6 个数据;Read 6 data from I2C device.
i2c.readfrom_mem(0x33,2,6) # 从 I2C 设备的寄存器 2 读取 6 个数据;Read 6 data from register 2 of the I2C device.
i2c.writeto_mem(0x33,2,[1,2,3,4,5]) # 向 I2C 设备的寄存器 2 写入 [1,2,3,4,5];Write [1,2,3,4,5] to register 2 of the I2C device;

while(1):
time.sleep(1)
```

Assume that an I2C device with address 0x33 is mounted on I2C3 of Duo. You can use a logic analyzer or other device to capture the level signal on I2C3 for analysis. Execute ```python i2c.py``` in the Duo terminal to run the program.

Because there is no I2C device with address 0x33 mounted on the bus, the program may return some error information after execution:

```
[root@milkv-duo]~# python ./i2c.py
milkv-duo
__________________________________________
| ____ _ ____ |
| / __ \(_)___ / __ \____ ____ ____ _ |
| / /_/ / / __ \/ /_/ / __ \/ __ \/ __ `/ |
| / ____/ / / / / ____/ /_/ / / / / /_/ / |
|/_/ /_/_/ /_/_/ \____/_/ /_/\__, / |
| v0.5.2 Designed by DFRobot /____/ |
|__________________________________________|
i2c list: []
Traceback (most recent call last):
File "/root/./i2c.py", line 21, in <module>
i2c.writeto(0x33,[1,2,3,4,5]) # 将 [1,2,3,4,5] 写入 I2C 设备;Write [1,2,3,4,5] to the I2C device.
File "/usr/lib/python3.9/site-packages/pinpong/board.py", line 823, in writeto
self.obj.writeto(i2c_addr, value)
File "/usr/lib/python3.9/site-packages/pinpong/board.py", line 781, in writeto
self.i2c.transfer(writing(i2c_addr, value))
File "/usr/lib/python3.9/site-packages/pinpong/base/i2c.py", line 89, in transfer
ioctl(self.fd, I2C_RDWR, ioctl_arg)
OSError: [Errno 121] Remote I/O error
```

## Other Examples

## Other examples
Please refer to:[github](https://github.com/milkv-duo/duo-buildroot-sdk/tree/develop/buildroot-2021.05/package/python-pinpong/pinpong/examples/milkv-Duo)

Please refer to: [github](https://github.com/milkv-duo/duo-buildroot-sdk/tree/develop/buildroot-2021.05/package/python-pinpong/pinpong/examples/milkv-Duo)
:::warning
The above examples have not been verified and may not work properly.
:::
Loading

0 comments on commit 4d3aee9

Please sign in to comment.