@@ -36,6 +36,7 @@ static int istep(uint32_t major, uint32_t minor)
{
struct pdbg_target *pib;
int count = 0, i, rc;
+ int first = minor, last = minor;
for_each_path_target_class("pib", pib) {
if (pdbg_target_index(pib))
@@ -59,6 +60,12 @@ static int istep(uint32_t major, uint32_t minor)
if (istep_data[i].major != major)
continue;
+ if (minor == 0) {
+ first = istep_data[i].minor_first;
+ last = istep_data[i].minor_last;
+ break;
+ }
+
if (minor < istep_data[i].minor_first ||
minor > istep_data[i].minor_last) {
fprintf(stderr, "Istep %d minor should be %d to %d\n",
@@ -69,10 +76,15 @@ static int istep(uint32_t major, uint32_t minor)
}
}
- rc = sbe_istep(pib, major, minor);
- if (!rc)
- count++;
+ for (i = first; i <= last ; i++) {
+ printf("Running istep %d.%d\n", major, i);
+ rc = sbe_istep(pib, major, i);
+ if (rc)
+ goto fail;
+ }
+ count++;
+fail:
return count;
}
OPTCMD_DEFINE_CMD_WITH_ARGS(istep, istep, (DATA32, DATA32));
@@ -125,7 +125,7 @@ static struct action actions[] = {
{ "sreset", "", "Reset" },
{ "regs", "[--backtrace]", "State (optionally display backtrace)" },
{ "gdbserver", "", "Start a gdb server" },
- { "istep", "<major> <minor>", "Execute istep on SBE" },
+ { "istep", "<major> <minor>|0", "Execute istep on SBE" },
};
static void print_usage(void)
Signed-off-by: Amitay Isaacs <amitay@ozlabs.org> --- src/istep.c | 18 +++++++++++++++--- src/main.c | 2 +- 2 files changed, 16 insertions(+), 4 deletions(-)