source: mainline/uspace/app/tmon/main.c@ b10a434

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since b10a434 was 2986763, checked in by Petr Mánek <petr.manek@…>, 8 years ago

tmon: refactoring

Stress tests have been renamed to burst tests because they do not fit the semantic definition of a stress tests. Instead, the read/write as much data as possible into given USB pipes, hence the name burst. They can be accessed using the tmon test-(intr|bulk|isoch)-(in|out) wildcard again. Files test.(c|h), which contain testing framework definitions now, have been renamed to more apt tf.(c.h).

  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2017 Petr Manek
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup tmon
30 * @{
31 */
32/**
33 * @file
34 * USB transfer debugging.
35 */
36
37#include <stdio.h>
38#include "commands.h"
39
40#define NAME "tmon"
41
42typedef struct {
43 const char *name;
44 const char *description;
45 int (*action)(int, char **);
46} usb_diag_cmd_t;
47
48static usb_diag_cmd_t commands[] = {
49 {
50 .name = "list",
51 .description = "Print a list of connected diagnostic devices.",
52 .action = tmon_list,
53 },
54 {
55 .name = "test-intr-in",
56 .description = "Read from interrupt in endpoints as fast as possible.",
57 .action = tmon_burst_intr_in,
58 },
59 {
60 .name = "test-intr-out",
61 .description = "Write to interrupt out endpoints as fast as possible.",
62 .action = tmon_burst_intr_out,
63 },
64 {
65 .name = "test-bulk-in",
66 .description = "Read from bulk in endpoints as fast as possible.",
67 .action = tmon_burst_bulk_in,
68 },
69 {
70 .name = "test-bulk-out",
71 .description = "Write to bulk out endpoints as fast as possible.",
72 .action = tmon_burst_bulk_out,
73 },
74 {
75 .name = "test-isoch-in",
76 .description = "Read from isochronous in endpoints as fast as possible.",
77 .action = tmon_burst_isoch_in,
78 },
79 {
80 .name = "test-isoch-out",
81 .description = "Write to isochronouse out endpoints as fast as possible.",
82 .action = tmon_burst_isoch_out,
83 },
84 {
85 .name = NULL
86 }
87};
88
89static void print_usage(char *app_name)
90{
91 printf(NAME ": benchmark USB diagnostic device\n\n");
92
93 printf("Usage: %s command [device] [options]\n", app_name);
94 printf("Available commands:\n");
95 for (int i = 0; commands[i].name; ++i) {
96 printf(" %s - %s\n", commands[i].name, commands[i].description);
97 }
98
99 // TODO: Print options.
100
101 printf("\nIf no device is specified, the first device is used provided that no other device is connected.\n\n");
102}
103
104int main(int argc, char *argv[])
105{
106 // Find a command to execute.
107 usb_diag_cmd_t *cmd = NULL;
108 for (int i = 0; argc > 1 && commands[i].name; ++i) {
109 if (str_cmp(argv[1], commands[i].name) == 0) {
110 cmd = commands + i;
111 break;
112 }
113 }
114
115 if (!cmd) {
116 print_usage(argv[0]);
117 return -1;
118 }
119
120 return cmd->action(argc - 1, argv + 1);
121}
122
123/** @}
124 */
Note: See TracBrowser for help on using the repository browser.