test 2.33 KB
Newer Older
1 2 3 4
#!/usr/bin/env python3

import os
import sys
lwc-tester committed
5
import time
6
import subprocess
7 8 9 10 11 12 13 14
import serial.tools.list_ports
from test_common import (
    LogicMultiplexerTimeMeasurements,
    parse_nist_aead_test_vectors,
    DeviceUnderTestAeadUARTP,
    eprint,
    run_nist_aead_test_line,
)
15 16


17 18 19 20 21 22 23 24 25
def get_serial():
    ports = serial.tools.list_ports.comports()
    devices = [
        p.device
        for p in ports
        if (p.vid == 4292 and p.pid == 60000)
    ]
    devices.sort()
    return devices[0]
26 27


28
class ESP32(DeviceUnderTestAeadUARTP):
29

30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
    def __init__(self, build_dir):
        DeviceUnderTestAeadUARTP.__init__(self)

        self.build_dir = build_dir

    def flash(self):
        pipe = subprocess.PIPE
        previous_dir = os.path.abspath(os.curdir)
        os.chdir(self.build_dir)
        cmd = ['platformio', 'run', '-e', 'esp32dev', '--target', 'upload']
        cmd.extend(['--upload-port', get_serial()])
        cmd.extend(['--upload-port', get_serial()])
        p = subprocess.Popen(
            cmd, stdout=sys.stderr, stdin=pipe)
        stdout, stderr = p.communicate("")
        eprint("Firmware flashed.")
        os.chdir(previous_dir)

    def dump_ram(self):
        return None
50 51 52


def main(argv):
53 54
    if len(argv) != 3:
        print("Usage: test LWC_AEAD_KAT.txt build_dir")
55
        return 1
56 57 58 59 60 61 62 63 64 65 66 67

    kat = list(parse_nist_aead_test_vectors(argv[1]))
    build_dir = argv[2]

    dut = ESP32(build_dir)

    try:
        tool = LogicMultiplexerTimeMeasurements(0x0030)
        tool.begin_measurement()

        dut.flash()

lwc-tester committed
68
        ser = serial.Serial(
69 70 71 72
            get_serial(),
            baudrate=500000,
            timeout=5)

lwc-tester committed
73 74 75 76 77 78 79 80 81
        ser.setDTR(False)  # IO0=HIGH
        ser.setRTS(True)   # EN=LOW, chip in reset
        time.sleep(0.1)
        ser.setDTR(False)  # IO0=HIGH
        ser.setRTS(False)  # EN=HIGH, chip out of reset
        time.sleep(1)

        dut.ser = ser

82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
        dut.prepare()
        sys.stdout.write("Board prepared\n")
        sys.stdout.flush()

        for i, m, ad, k, npub, c in kat:
            tool.arm()
            run_nist_aead_test_line(dut, i, m, ad, k, npub, c)
            tool.unarm()

    except Exception as ex:
        print("TEST FAILED")
        raise ex

    finally:
        tool.end_measurement()
        sys.stdout.flush()
        sys.stderr.flush()
99 100 101 102


if __name__ == "__main__":
    sys.exit(main(sys.argv))