Skip to content

Commit

Permalink
revalidator: Improve logging for transition_ukey().
Browse files Browse the repository at this point in the history
There are a few cases where more introspection into ukey transitions
would be relevant for logging or assertion. Track the SOURCE_LOCATOR and
thread id when states are transitioned and use these for logging.

Suggested-by: Jarno Rajahalme <[email protected]>
Signed-off-by: Joe Stringer <[email protected]>
Acked-by: Ben Pfaff <[email protected]>
  • Loading branch information
joestringer committed Apr 27, 2017
1 parent 6997d54 commit b5a7587
Showing 1 changed file with 22 additions and 3 deletions.
25 changes: 22 additions & 3 deletions ofproto/ofproto-dpif-upcall.c
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,10 @@ struct udpif_key {
uint64_t reval_seq OVS_GUARDED; /* Tracks udpif->reval_seq. */
enum ukey_state state OVS_GUARDED; /* Tracks ukey lifetime. */

/* 'state' debug information. */
unsigned int state_thread OVS_GUARDED; /* Thread that transitions. */
const char *state_where OVS_GUARDED; /* transition_ukey() locator. */

/* Datapath flow actions as nlattrs. Protected by RCU. Read with
* ukey_get_actions(), and write with ukey_set_actions(). */
OVSRCU_TYPE(struct ofpbuf *) actions;
Expand Down Expand Up @@ -350,8 +354,11 @@ static void ukey_get_actions(struct udpif_key *, const struct nlattr **actions,
static bool ukey_install__(struct udpif *, struct udpif_key *ukey)
OVS_TRY_LOCK(true, ukey->mutex);
static bool ukey_install(struct udpif *udpif, struct udpif_key *ukey);
static void transition_ukey(struct udpif_key *ukey, enum ukey_state dst)
static void transition_ukey_at(struct udpif_key *ukey, enum ukey_state dst,
const char *where)
OVS_REQUIRES(ukey->mutex);
#define transition_ukey(UKEY, DST) \
transition_ukey_at(UKEY, DST, OVS_SOURCE_LOCATOR)
static struct udpif_key *ukey_lookup(struct udpif *udpif,
const ovs_u128 *ufid,
const unsigned pmd_id);
Expand Down Expand Up @@ -1484,6 +1491,8 @@ ukey_create__(const struct nlattr *key, size_t key_len,
ukey->dump_seq = dump_seq;
ukey->reval_seq = reval_seq;
ukey->state = UKEY_CREATED;
ukey->state_thread = ovsthread_id_self();
ukey->state_where = OVS_SOURCE_LOCATOR;
ukey->created = time_msec();
memset(&ukey->stats, 0, sizeof ukey->stats);
ukey->stats.used = used;
Expand Down Expand Up @@ -1671,10 +1680,15 @@ ukey_install__(struct udpif *udpif, struct udpif_key *new_ukey)
}

static void
transition_ukey(struct udpif_key *ukey, enum ukey_state dst)
transition_ukey_at(struct udpif_key *ukey, enum ukey_state dst,
const char *where)
OVS_REQUIRES(ukey->mutex)
{
ovs_assert(dst >= ukey->state);
if (dst < ukey->state) {
VLOG_ABORT("Invalid ukey transition %d->%d (last transitioned from "
"thread %u at %s)", ukey->state, dst, ukey->state_thread,
ukey->state_where);
}
if (ukey->state == dst && dst == UKEY_OPERATIONAL) {
return;
}
Expand Down Expand Up @@ -1709,6 +1723,8 @@ transition_ukey(struct udpif_key *ukey, enum ukey_state dst)
ds_cstr(&ds), ukey->state, dst);
ds_destroy(&ds);
}
ukey->state_thread = ovsthread_id_self();
ukey->state_where = where;
}

static bool
Expand Down Expand Up @@ -2327,6 +2343,9 @@ revalidate(struct revalidator *revalidator)
/* The flow is now confirmed to be in the datapath. */
transition_ukey(ukey, UKEY_OPERATIONAL);
} else {
VLOG_INFO("Unexpected ukey transition from state %d "
"(last transitioned from thread %u at %s)",
ukey->state, ukey->state_thread, ukey->state_where);
ovs_mutex_unlock(&ukey->mutex);
continue;
}
Expand Down

0 comments on commit b5a7587

Please sign in to comment.