X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fofp-parse.c;h=c759f036b7bab05f6dd7e08aeef57f47bb15e8f0;hb=dc723c447a797e555d400594133a35b9841eb1de;hp=5c5bb0647dbfcf008b7608727eee7df36bba8af4;hpb=9c4dbc1caa7f83c16775406547f9cfba38c8d513;p=sliver-openvswitch.git diff --git a/lib/ofp-parse.c b/lib/ofp-parse.c index 5c5bb0647..c759f036b 100644 --- a/lib/ofp-parse.c +++ b/lib/ofp-parse.c @@ -291,7 +291,7 @@ parse_note(const char *arg, struct ofpbuf *ofpacts) } ofpbuf_put(ofpacts, &byte, 1); - note = ofpacts->l2; + note = ofpacts->frame; note->length++; arg += 2; @@ -400,7 +400,7 @@ parse_noargs_dec_ttl(struct ofpbuf *b) ids = ofpact_put_DEC_TTL(b); ofpbuf_put(b, &id, sizeof id); - ids = b->l2; + ids = b->frame; ids->n_controllers++; ofpact_update_len(b, &ids->ofpact); } @@ -426,7 +426,7 @@ parse_dec_ttl(struct ofpbuf *b, char *arg) uint16_t id = atoi(cntr); ofpbuf_put(b, &id, sizeof id); - ids = b->l2; + ids = b->frame; ids->n_controllers++; } if (!ids->n_controllers) { @@ -632,7 +632,7 @@ parse_named_action(enum ofputil_action_code code, char *arg, struct ofpbuf *ofpacts, enum ofputil_protocol *usable_protocols) { - size_t orig_size = ofpacts->size; + size_t orig_size = ofpbuf_size(ofpacts); struct ofpact_tunnel *tunnel; struct ofpact_vlan_vid *vlan_vid; struct ofpact_vlan_pcp *vlan_pcp; @@ -929,7 +929,7 @@ parse_named_action(enum ofputil_action_code code, } if (error) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); } return error; } @@ -978,7 +978,7 @@ static char * WARN_UNUSED_RESULT str_to_ofpacts__(char *str, struct ofpbuf *ofpacts, enum ofputil_protocol *usable_protocols) { - size_t orig_size = ofpacts->size; + size_t orig_size = ofpbuf_size(ofpacts); char *pos, *act, *arg; int n_actions; @@ -988,7 +988,7 @@ str_to_ofpacts__(char *str, struct ofpbuf *ofpacts, char *error = str_to_ofpact__(pos, act, arg, ofpacts, n_actions, usable_protocols); if (error) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); return error; } n_actions++; @@ -1007,7 +1007,7 @@ static char * WARN_UNUSED_RESULT str_to_ofpacts(char *str, struct ofpbuf *ofpacts, enum ofputil_protocol *usable_protocols) { - size_t orig_size = ofpacts->size; + size_t orig_size = ofpbuf_size(ofpacts); char *error_s; enum ofperr error; @@ -1016,9 +1016,9 @@ str_to_ofpacts(char *str, struct ofpbuf *ofpacts, return error_s; } - error = ofpacts_verify(ofpacts->data, ofpacts->size); + error = ofpacts_verify(ofpbuf_data(ofpacts), ofpbuf_size(ofpacts)); if (error) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); return xstrdup("Incorrect action ordering"); } @@ -1050,16 +1050,16 @@ parse_named_instruction(enum ovs_instruction_type type, size_t ofs; ofpact_pad(ofpacts); - ofs = ofpacts->size; + ofs = ofpbuf_size(ofpacts); on = ofpact_put(ofpacts, OFPACT_WRITE_ACTIONS, offsetof(struct ofpact_nest, actions)); error_s = str_to_ofpacts__(arg, ofpacts, usable_protocols); on = ofpbuf_at_assert(ofpacts, ofs, sizeof *on); - on->ofpact.len = ofpacts->size - ofs; + on->ofpact.len = ofpbuf_size(ofpacts) - ofs; if (error_s) { - ofpacts->size = ofs; + ofpbuf_set_size(ofpacts, ofs); } break; } @@ -1095,7 +1095,7 @@ parse_named_instruction(enum ovs_instruction_type type, /* If write_metadata is specified as an action AND an instruction, ofpacts could be invalid. */ - error = ofpacts_verify(ofpacts->data, ofpacts->size); + error = ofpacts_verify(ofpbuf_data(ofpacts), ofpbuf_size(ofpacts)); if (error) { return xstrdup("Incorrect instruction ordering"); } @@ -1110,7 +1110,7 @@ static char * WARN_UNUSED_RESULT str_to_inst_ofpacts(char *str, struct ofpbuf *ofpacts, enum ofputil_protocol *usable_protocols) { - size_t orig_size = ofpacts->size; + size_t orig_size = ofpbuf_size(ofpacts); char *pos, *inst, *arg; int type; const char *prev_inst = NULL; @@ -1124,7 +1124,7 @@ str_to_inst_ofpacts(char *str, struct ofpbuf *ofpacts, char *error = str_to_ofpact__(pos, inst, arg, ofpacts, n_actions, usable_protocols); if (error) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); return error; } @@ -1134,20 +1134,20 @@ str_to_inst_ofpacts(char *str, struct ofpbuf *ofpacts, continue; } } else if (type == OVSINST_OFPIT11_APPLY_ACTIONS) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); return xasprintf("%s isn't supported. Just write actions then " "it is interpreted as apply_actions", inst); } else { char *error = parse_named_instruction(type, arg, ofpacts, usable_protocols); if (error) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); return error; } } if (type <= prev_type) { - ofpacts->size = orig_size; + ofpbuf_set_size(ofpacts, orig_size); if (type == prev_type) { return xasprintf("instruction %s may be specified only once", inst); @@ -1326,6 +1326,9 @@ parse_ofp_str__(struct ofputil_flow_mod *fm, int command, char *string, } else if (fields & F_FLAGS && !strcmp(name, "no_byte_counts")) { fm->flags |= OFPUTIL_FF_NO_BYT_COUNTS; *usable_protocols &= OFPUTIL_P_OF13_UP; + } else if (!strcmp(name, "no_readonly_table") + || !strcmp(name, "allow_hidden_fields")) { + /* ignore these fields. */ } else { char *value; @@ -1433,7 +1436,7 @@ parse_ofp_str__(struct ofputil_flow_mod *fm, int command, char *string, if (!error) { enum ofperr err; - err = ofpacts_check(ofpacts.data, ofpacts.size, &fm->match.flow, + err = ofpacts_check(ofpbuf_data(&ofpacts), ofpbuf_size(&ofpacts), &fm->match.flow, OFPP_MAX, fm->table_id, 255, usable_protocols); if (!err && !usable_protocols) { err = OFPERR_OFPBAC_MATCH_INCONSISTENT; @@ -1449,7 +1452,7 @@ parse_ofp_str__(struct ofputil_flow_mod *fm, int command, char *string, return error; } - fm->ofpacts_len = ofpacts.size; + fm->ofpacts_len = ofpbuf_size(&ofpacts); fm->ofpacts = ofpbuf_steal_data(&ofpacts); } else { fm->ofpacts_len = 0; @@ -1921,7 +1924,7 @@ parse_ofp_flow_mod_file(const char *file_name, uint16_t command, size_t i; for (i = 0; i < *n_fms; i++) { - free((*fms)[i].ofpacts); + free(CONST_CAST(struct ofpact *, (*fms)[i].ofpacts)); } free(*fms); *fms = NULL; @@ -2130,8 +2133,8 @@ parse_bucket_str(struct ofputil_bucket *bucket, char *str_, } ofpact_pad(&ofpacts); - bucket->ofpacts = ofpacts.data; - bucket->ofpacts_len = ofpacts.size; + bucket->ofpacts = ofpbuf_data(&ofpacts); + bucket->ofpacts_len = ofpbuf_size(&ofpacts); return NULL; }