2022-03-08 11:15:37 +08:00
|
|
|
# SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
# SPDX-License-Identifier: CC0-1.0
|
|
|
|
|
2022-05-26 11:30:31 +08:00
|
|
|
import time
|
|
|
|
|
2022-03-08 11:15:37 +08:00
|
|
|
import pexpect
|
|
|
|
import pytest
|
|
|
|
from pytest_embedded import Dut
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.esp32s2
|
2022-05-26 11:30:31 +08:00
|
|
|
@pytest.mark.esp32s3
|
2022-06-23 17:26:51 +08:00
|
|
|
@pytest.mark.generic
|
2022-03-08 11:15:37 +08:00
|
|
|
def test_ulp_riscv_gpio(dut: Dut) -> None:
|
|
|
|
|
|
|
|
dut.expect_exact('Not a ULP-RISC-V wakeup, initializing it!')
|
|
|
|
dut.expect_exact('Entering in deep sleep')
|
|
|
|
|
2022-05-26 11:30:31 +08:00
|
|
|
# Give the chip time to enter deepsleep
|
|
|
|
time.sleep(1)
|
|
|
|
|
2022-03-08 11:15:37 +08:00
|
|
|
# Run two times to make sure device sleep
|
|
|
|
# and wake up properly
|
|
|
|
for i in range(0, 2):
|
|
|
|
# Set GPIO0 using DTR
|
|
|
|
dut.serial.proc.setDTR(i % 2 == 0)
|
|
|
|
|
|
|
|
dut.expect_exact('ULP-RISC-V woke up the main CPU!', timeout=5)
|
|
|
|
|
|
|
|
# Check GPIO state
|
|
|
|
state = 'Low' if i % 2 == 0 else 'High'
|
|
|
|
dut.expect(r'ULP-RISC-V read changes in GPIO_0 current is: %s' % state, timeout=5)
|
|
|
|
|
|
|
|
# Go back to sleep
|
|
|
|
dut.expect_exact('Entering in deep sleep', timeout=5)
|
|
|
|
|
|
|
|
try:
|
|
|
|
# We expect a timeout here, otherwise it means that
|
|
|
|
# the main CPU woke up unexpectedly!
|
|
|
|
dut.expect('ULP-RISC-V woke up the main CPU!', timeout=20)
|
|
|
|
raise Exception('Main CPU woke up unexpectedly!')
|
|
|
|
except pexpect.exceptions.TIMEOUT:
|
|
|
|
pass
|