summaryrefslogtreecommitdiffstats
path: root/classes/zephyr-flash-pyocd.bbclass
blob: a873be4d307bb9cf8bd07962dc57d51a46452489 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
PYOCD_CONNECT_TIMEOUT_SECONDS ?= "30"
PYOCD_FLASH_IDS ?= "all"

python do_flash_usb() {
    try:
        from pyocd.core.helpers import ConnectHelper
        from pyocd.flash.file_programmer import FileProgrammer
    except ImportError:
        bb.fatal("Flashing with pyocd needs the relevant python package. Make sure your host provides it or consult your distribution packages for how to install this prerequisite.")

    try:
        timeout = int(d.getVar('PYOCD_CONNECT_TIMEOUT_SECONDS'))
    except ValueError:
        bb.fatal(f"PYOCD_CONNECT_TIMEOUT_SECONDS was set to an invalid value: {d.getVar('PYOCD_CONNECT_TIMEOUT_SECONDS')}.")
    image = f"{d.getVar('DEPLOY_DIR_IMAGE')}/{d.getVar('PN')}.elf"
    ids = d.getVar('PYOCD_FLASH_IDS')

    # Compute the list of IDs to program
    if ids == 'all':
        ids = []
        for probe in ConnectHelper.get_all_connected_probes(blocking=False):
            ids.append(probe.unique_id)
        if not ids:
            bb.fatal("No probe detected. Make sure your target is connected.")
    else:
        ids = ids.split()
        if not ids:
            bb.fatal("No probe requested for programming. Make sure PYOCD_FLASH_IDS is set.")

    # Program each ID
    for id in ids:
        bb.plain(f"Attempting to flash {os.path.basename(image)} to board {d.getVar('BOARD')} [{id}]")

        # Try to connect to a probe with a timeout
        now = 0
        step = 3
        while True:
            session = ConnectHelper.session_with_chosen_probe(blocking=False, return_first=True, unique_id=id)
            if session:
                break
            if now >= timeout:
                bb.fatal(f"Timeout while trying to connect to probe ID: {id}. Make sure the target device is connected and the udev is configured accordingly. See <https://github.com/mbedmicro/pyOCD/tree/master/udev> for help.")
            bb.warn(f"Can't connect to the probe ID: {id}. Retrying in {step} seconds...")
            time.sleep(step)
            now += step

        # Program the selected probe
        with session:
            FileProgrammer(session).program(image)
            session.board.target.reset()
}

addtask do_flash_usb after do_deploy

do_flash_usb[nostamp] = "1"
do_flash_usb[vardepsexclude] = "BB_ORIGENV"