X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fpg%2Fedit.c;h=df057d2ba709e3bfc8a55e8b07cec5c49427ce83;hb=30928f87a3c9d98e288d1364d50c032e052e69ab;hp=a0aab1fb5666227ccc2ce9561349cc3f62cfd0e1;hpb=4222347a87994cc109499ebe67498792c0e705f8;p=vpp.git diff --git a/src/vnet/pg/edit.c b/src/vnet/pg/edit.c index a0aab1fb566..df057d2ba70 100644 --- a/src/vnet/pg/edit.c +++ b/src/vnet/pg/edit.c @@ -129,16 +129,19 @@ unformat_pg_payload (unformat_input_t * input, va_list * args) pg_stream_t *s = va_arg (*args, pg_stream_t *); vlib_main_t *vm = vlib_get_main (); pg_edit_t *e; - u32 i, node_index, len, max_len, ilen; + u32 i, node_index, len, max_len; u8 *v; v = 0; - if (unformat (input, "incrementing %d", &ilen)) - ; + if (unformat (input, "incrementing %d", &len)) + { + vec_resize (v, len); + for (i = 0; i < len; i++) + v[i] = i % len; + } else if (unformat (input, "hex 0x%U", unformat_hex_string, &v)) ; - else if (unformat (input, "%U", unformat_vlib_node, vm, &node_index)) { pg_node_t *pn = pg_get_node (node_index); @@ -152,6 +155,7 @@ unformat_pg_payload (unformat_input_t * input, va_list * args) /* Length not including this payload. */ max_len = pg_edit_group_n_bytes (s, 0); + if (max_len >= s->max_packet_bytes) { /* no payload */ @@ -164,16 +168,14 @@ unformat_pg_payload (unformat_input_t * input, va_list * args) } vec_resize (v, len); - for (i = 0; i < len; i++) - v[i] = i % ilen; - e = pg_create_edit_group (s, sizeof (e[0]), 0, 0); + e = pg_create_edit_group (s, sizeof (e[0]), len, 0); e->type = PG_EDIT_FIXED; - e->n_bits = vec_len (v) * BITS (v[0]); + e->n_bits = len * BITS (v[0]); /* Least significant bit is at end of bitstream, since everything is always bigendian. */ - e->lsb_bit_offset = e->n_bits - BITS (v[0]); + e->lsb_bit_offset = len > 0 ? e->n_bits - BITS (v[0]) : 0; e->values[PG_EDIT_LO] = v;