Browse Source

jtag: avoid using interp global variable

Adds 'interp' field to jtag_tap_event_action structure to avoid
using the global variable of same name.
tags/v0.4.0-rc1
Zachary T Welch 14 years ago
parent
commit
e1ee270265
2 changed files with 13 additions and 6 deletions
  1. +8
    -3
      src/jtag/jtag.h
  2. +5
    -3
      src/jtag/tcl.c

+ 8
- 3
src/jtag/jtag.h View File

@@ -209,9 +209,14 @@ enum jtag_event {

struct jtag_tap_event_action
{
enum jtag_event event;
Jim_Obj* body;
struct jtag_tap_event_action* next;
/// The event for which this action will be triggered.
enum jtag_event event;
/// The interpreter to use for evaluating the @c body.
Jim_Interp *interp;
/// Contains a script to 'eval' when the @c event is triggered.
Jim_Obj *body;
// next action in linked list
struct jtag_tap_event_action *next;
};

/**


+ 5
- 3
src/jtag/tcl.c View File

@@ -341,8 +341,9 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
if (!found)
jteap = calloc(1, sizeof(*jteap));
else if (NULL != jteap->body)
Jim_DecrRefCount(interp, jteap->body);
Jim_DecrRefCount(goi->interp, jteap->body);

jteap->interp = goi->interp;
jteap->event = n->value;

Jim_Obj *o;
@@ -359,6 +360,7 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
}
else if (found)
{
jteap->interp = goi->interp;
Jim_SetResult(goi->interp,
Jim_DuplicateObj(goi->interp, jteap->body));
}
@@ -616,9 +618,9 @@ static void jtag_tap_handle_event(struct jtag_tap *tap, enum jtag_event e)
tap->dotted_name, e, nvp->name,
Jim_GetString(jteap->body, NULL));

if (Jim_EvalObj(interp, jteap->body) != JIM_OK)
if (Jim_EvalObj(jteap->interp, jteap->body) != JIM_OK)
{
Jim_PrintErrorMessage(interp);
Jim_PrintErrorMessage(jteap->interp);
continue;
}



Loading…
Cancel
Save