Merge pull request #2761 from hathach/hil-readd-v203
readd v203 to hil pool
This commit is contained in:
		| @@ -345,12 +345,14 @@ static void handle_ctr_rx(uint32_t ep_id) { | ||||
|  | ||||
|   if ((rx_count < xfer->max_packet_size) || (xfer->queued_len >= xfer->total_len)) { | ||||
|     // all bytes received or short packet | ||||
|     dcd_event_xfer_complete(0, ep_num, xfer->queued_len, XFER_RESULT_SUCCESS, true); | ||||
|  | ||||
|     // For ch32v203: reset rx bufsize to mps to prevent race condition to cause PMAOVR (occurs with msc write10) | ||||
|     // also ch32 seems to unconditionally accept ZLP on EP0 OUT, which can incorrectly use queued_len of previous | ||||
|     // transfer. So reset total_len and queued_len to 0. | ||||
|     btable_set_rx_bufsize(ep_id, BTABLE_BUF_RX, xfer->max_packet_size); | ||||
|  | ||||
|     dcd_event_xfer_complete(0, ep_num, xfer->queued_len, XFER_RESULT_SUCCESS, true); | ||||
|  | ||||
|     // ch32 seems to unconditionally accept ZLP on EP0 OUT, which can incorrectly use queued_len of previous | ||||
|     // transfer. So reset total_len and queued_len to 0. | ||||
|     xfer->total_len = xfer->queued_len = 0; | ||||
|   } else { | ||||
|     // Set endpoint active again for receiving more data. Note that isochronous endpoints stay active always | ||||
| @@ -412,11 +414,6 @@ void dcd_int_handler(uint8_t rhport) { | ||||
|     FSDEV_REG->ISTR = (fsdev_bus_t)~USB_ISTR_ESOF; | ||||
|   } | ||||
|  | ||||
|   if (int_status & USB_ISTR_PMAOVR) { | ||||
|     TU_BREAKPOINT(); | ||||
|     FSDEV_REG->ISTR = (fsdev_bus_t)~USB_ISTR_PMAOVR; | ||||
|   } | ||||
|  | ||||
|   // loop to handle all pending CTR interrupts | ||||
|   while (FSDEV_REG->ISTR & USB_ISTR_CTR) { | ||||
|     // skip DIR bit, and use CTR TX/RX instead, since there is chance we have both TX/RX completed in one interrupt | ||||
| @@ -459,6 +456,11 @@ void dcd_int_handler(uint8_t rhport) { | ||||
|       handle_ctr_tx(ep_id); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (int_status & USB_ISTR_PMAOVR) { | ||||
|     TU_BREAKPOINT(); | ||||
|     FSDEV_REG->ISTR = (fsdev_bus_t)~USB_ISTR_PMAOVR; | ||||
|   } | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| @@ -806,6 +808,10 @@ void dcd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr) { | ||||
|   ep_write(ep_idx, ep_reg, true); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // PMA read/write | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Write to packet memory area (PMA) from user memory | ||||
| // - Packet memory must be either strictly 16-bit or 32-bit depending on FSDEV_BUS_32BIT | ||||
| // - Uses unaligned for RAM (since M0 cannot access unaligned address) | ||||
|   | ||||
| @@ -285,8 +285,9 @@ TU_ATTR_ALWAYS_INLINE static inline void btable_set_rx_bufsize(uint32_t ep_id, u | ||||
|   /* Encode into register. When BLSIZE==1, we need to subtract 1 block count */ | ||||
|   uint16_t bl_nb = (blsize << 15) | ((num_block - blsize) << 10); | ||||
|   if (bl_nb == 0) { | ||||
|     // zlp but 0 is invalid value, set num_block to 1 (2 bytes) | ||||
|     bl_nb = 1 << 10; | ||||
|     // zlp but 0 is invalid value, set blsize to 1 (32 bytes) | ||||
|     // Note: lower value can cause PMAOVR on setup with ch32v203 | ||||
|     bl_nb = 1 << 15; | ||||
|   } | ||||
|  | ||||
| #ifdef FSDEV_BUS_32BIT | ||||
|   | ||||
| @@ -36,7 +36,7 @@ import glob | ||||
| import platform | ||||
| from multiprocessing import Pool | ||||
|  | ||||
| ENUM_TIMEOUT = 30 | ||||
| ENUM_TIMEOUT = 20 | ||||
|  | ||||
|  | ||||
| # get usb serial by id | ||||
| @@ -110,7 +110,8 @@ def run_cmd(cmd): | ||||
|     #print(cmd) | ||||
|     r = subprocess.run(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) | ||||
|     if r.returncode != 0: | ||||
|         title = 'command error' | ||||
|         title = f'COMMAND FAILED: {cmd}' | ||||
|         print() | ||||
|         if os.getenv('CI'): | ||||
|             print(f"::group::{title}") | ||||
|             print(r.stdout.decode("utf-8")) | ||||
| @@ -198,14 +199,15 @@ def flash_esptool(board, firmware): | ||||
| # ------------------------------------------------------------- | ||||
| # Tests | ||||
| # ------------------------------------------------------------- | ||||
| def test_board_test(id): | ||||
| def test_board_test(board): | ||||
|     # Dummy test | ||||
|     pass | ||||
|  | ||||
|  | ||||
| def test_cdc_dual_ports(id): | ||||
|     port1 = get_serial_dev(id, 'TinyUSB', "TinyUSB_Device", 0) | ||||
|     port2 = get_serial_dev(id, 'TinyUSB', "TinyUSB_Device", 2) | ||||
| def test_cdc_dual_ports(board): | ||||
|     uid = board['uid'] | ||||
|     port1 = get_serial_dev(uid, 'TinyUSB', "TinyUSB_Device", 0) | ||||
|     port2 = get_serial_dev(uid, 'TinyUSB', "TinyUSB_Device", 2) | ||||
|  | ||||
|     ser1 = open_serial_dev(port1) | ||||
|     ser2 = open_serial_dev(port2) | ||||
| @@ -224,9 +226,10 @@ def test_cdc_dual_ports(id): | ||||
|     assert ser2.read(100) == str2.upper(), 'Port2 wrong data' | ||||
|  | ||||
|  | ||||
| def test_cdc_msc(id): | ||||
| def test_cdc_msc(board): | ||||
|     uid = board['uid'] | ||||
|     # Echo test | ||||
|     port = get_serial_dev(id, 'TinyUSB', "TinyUSB_Device", 0) | ||||
|     port = get_serial_dev(uid, 'TinyUSB', "TinyUSB_Device", 0) | ||||
|     ser = open_serial_dev(port) | ||||
|  | ||||
|     str = b"test_str" | ||||
| @@ -235,7 +238,7 @@ def test_cdc_msc(id): | ||||
|     assert ser.read(100) == str, 'CDC wrong data' | ||||
|  | ||||
|     # Block test | ||||
|     data = read_disk_file(id, 'README.TXT') | ||||
|     data = read_disk_file(uid, 'README.TXT') | ||||
|     readme = \ | ||||
|     b"This is tinyusb's MassStorage Class demo.\r\n\r\n\ | ||||
| If you find any bugs or get any questions, feel free to file an\r\n\ | ||||
| @@ -244,26 +247,28 @@ issue at github.com/hathach/tinyusb" | ||||
|     assert data == readme, 'MSC wrong data' | ||||
|  | ||||
|  | ||||
| def test_cdc_msc_freertos(id): | ||||
|     test_cdc_msc(id) | ||||
| def test_cdc_msc_freertos(board): | ||||
|     test_cdc_msc(board) | ||||
|  | ||||
|  | ||||
| def test_dfu(id): | ||||
| def test_dfu(board): | ||||
|     uid = board['uid'] | ||||
|  | ||||
|     # Wait device enum | ||||
|     timeout = ENUM_TIMEOUT | ||||
|     while timeout: | ||||
|         ret = subprocess.run(f'dfu-util -l', | ||||
|                              shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) | ||||
|         stdout = ret.stdout.decode() | ||||
|         if f'serial="{id}"' in stdout and 'Found DFU: [cafe:4000]' in stdout: | ||||
|         if f'serial="{uid}"' in stdout and 'Found DFU: [cafe:4000]' in stdout: | ||||
|             break | ||||
|         time.sleep(1) | ||||
|         timeout = timeout - 1 | ||||
|  | ||||
|     assert timeout, 'Device not available' | ||||
|  | ||||
|     f_dfu0 = f'dfu0_{id}' | ||||
|     f_dfu1 = f'dfu1_{id}' | ||||
|     f_dfu0 = f'dfu0_{uid}' | ||||
|     f_dfu1 = f'dfu1_{uid}' | ||||
|  | ||||
|     # Test upload | ||||
|     try: | ||||
| @@ -272,10 +277,10 @@ def test_dfu(id): | ||||
|     except OSError: | ||||
|         pass | ||||
|  | ||||
|     ret = run_cmd(f'dfu-util -S {id} -a 0 -U {f_dfu0}') | ||||
|     ret = run_cmd(f'dfu-util -S {uid} -a 0 -U {f_dfu0}') | ||||
|     assert ret.returncode == 0, 'Upload failed' | ||||
|  | ||||
|     ret = run_cmd(f'dfu-util -S {id} -a 1 -U {f_dfu1}') | ||||
|     ret = run_cmd(f'dfu-util -S {uid} -a 1 -U {f_dfu1}') | ||||
|     assert ret.returncode == 0, 'Upload failed' | ||||
|  | ||||
|     with open(f_dfu0) as f: | ||||
| @@ -288,14 +293,16 @@ def test_dfu(id): | ||||
|     os.remove(f_dfu1) | ||||
|  | ||||
|  | ||||
| def test_dfu_runtime(id): | ||||
| def test_dfu_runtime(board): | ||||
|     uid = board['uid'] | ||||
|  | ||||
|     # Wait device enum | ||||
|     timeout = ENUM_TIMEOUT | ||||
|     while timeout: | ||||
|         ret = subprocess.run(f'dfu-util -l', | ||||
|                              shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) | ||||
|         stdout = ret.stdout.decode() | ||||
|         if f'serial="{id}"' in stdout and 'Found Runtime: [cafe:4000]' in stdout: | ||||
|         if f'serial="{uid}"' in stdout and 'Found Runtime: [cafe:4000]' in stdout: | ||||
|             break | ||||
|         time.sleep(1) | ||||
|         timeout = timeout - 1 | ||||
| @@ -303,10 +310,11 @@ def test_dfu_runtime(id): | ||||
|     assert timeout, 'Device not available' | ||||
|  | ||||
|  | ||||
| def test_hid_boot_interface(id): | ||||
|     kbd = get_hid_dev(id, 'TinyUSB', 'TinyUSB_Device', 'event-kbd') | ||||
|     mouse1 = get_hid_dev(id, 'TinyUSB', 'TinyUSB_Device', 'if01-event-mouse') | ||||
|     mouse2 = get_hid_dev(id, 'TinyUSB', 'TinyUSB_Device', 'if01-mouse') | ||||
| def test_hid_boot_interface(board): | ||||
|     uid = board['uid'] | ||||
|     kbd = get_hid_dev(uid, 'TinyUSB', 'TinyUSB_Device', 'event-kbd') | ||||
|     mouse1 = get_hid_dev(uid, 'TinyUSB', 'TinyUSB_Device', 'if01-event-mouse') | ||||
|     mouse2 = get_hid_dev(uid, 'TinyUSB', 'TinyUSB_Device', 'if01-mouse') | ||||
|     # Wait device enum | ||||
|     timeout = ENUM_TIMEOUT | ||||
|     while timeout: | ||||
| @@ -338,22 +346,23 @@ all_tests = [ | ||||
| ] | ||||
|  | ||||
|  | ||||
| def test_board(item): | ||||
|     name = item['name'] | ||||
|     flasher = item['flasher'].lower() | ||||
| def test_board(board): | ||||
|     name = board['name'] | ||||
|     flasher = board['flasher'].lower() | ||||
|  | ||||
|     # default to all tests | ||||
|     if 'tests' in item: | ||||
|         test_list = item['tests'] + ['board_test'] | ||||
|     if 'tests' in board: | ||||
|         test_list = board['tests'] + ['board_test'] | ||||
|     else: | ||||
|         test_list = list(all_tests) | ||||
|  | ||||
|     # remove skip_tests | ||||
|     if 'tests_skip' in item: | ||||
|         for skip in item['tests_skip']: | ||||
|     if 'tests_skip' in board: | ||||
|         for skip in board['tests_skip']: | ||||
|             if skip in test_list: | ||||
|                 test_list.remove(skip) | ||||
|  | ||||
|     err_count = 0 | ||||
|     for test in test_list: | ||||
|         fw_dir = f'cmake-build/cmake-build-{name}/device/{test}' | ||||
|         if not os.path.exists(fw_dir): | ||||
| @@ -367,19 +376,26 @@ def test_board(item): | ||||
|  | ||||
|         # flash firmware. It may fail randomly, retry a few times | ||||
|         for i in range(3): | ||||
|             ret = globals()[f'flash_{flasher}'](item, fw_name) | ||||
|             ret = globals()[f'flash_{flasher}'](board, fw_name) | ||||
|             if ret.returncode == 0: | ||||
|                 break | ||||
|             else: | ||||
|                 print(f'Flashing failed, retry {i+1}') | ||||
|                 time.sleep(1) | ||||
|  | ||||
|         assert ret.returncode == 0, 'Flash failed\n' + ret.stdout.decode() | ||||
|  | ||||
|         # run test | ||||
|         globals()[f'test_{test}'](item['uid']) | ||||
|         print('OK') | ||||
|         if ret.returncode == 0: | ||||
|             try: | ||||
|                 ret = globals()[f'test_{test}'](board) | ||||
|                 print('OK') | ||||
|             except AssertionError as e: | ||||
|                 err_count += 1 | ||||
|                 print('Failed') | ||||
|                 print(f'  {e}') | ||||
|         else: | ||||
|             err_count += 1 | ||||
|             print('Flash failed') | ||||
|  | ||||
|     return err_count | ||||
|  | ||||
| def main(): | ||||
|     """ | ||||
| @@ -404,8 +420,11 @@ def main(): | ||||
|     else: | ||||
|         config_boards = [e for e in config['boards'] if e['name'] in boards] | ||||
|  | ||||
|     err_count_list = 0 | ||||
|     with Pool(processes=os.cpu_count()) as pool: | ||||
|         pool.map(test_board, config_boards) | ||||
|         err_count_list = pool.map(test_board, config_boards) | ||||
|  | ||||
|     sys.exit(sum(err_count_list)) | ||||
|  | ||||
|  | ||||
| if __name__ == '__main__': | ||||
|   | ||||
| @@ -57,16 +57,16 @@ | ||||
|             "flasher": "openocd", | ||||
|             "flasher_sn": "066FFF495087534867063844", | ||||
|             "flasher_args": "-f interface/stlink.cfg -f target/stm32g0x.cfg" | ||||
|         } | ||||
|     ], | ||||
|     "boards-skip": [ | ||||
|         }, | ||||
|         { | ||||
|             "name": "nanoch32v203", | ||||
|             "uid": "CDAB277B0FBC03E339E339E3", | ||||
|             "flasher": "openocd_wch", | ||||
|             "flasher_sn": "EBCA8F0670AF", | ||||
|             "flasher_args": "" | ||||
|         }, | ||||
|         } | ||||
|     ], | ||||
|     "boards-skip": [ | ||||
|         { | ||||
|             "name": "espressif_s3_devkitm", | ||||
|             "uid": "84F703C084E4", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Ha Thach
					Ha Thach