X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=tests%2Ftest-stp.c;h=fecada712787351feb6d848bb43f799df47ce810;hb=c06bba01302e3dc1ec7808024bc37ce90956b49e;hp=c2a58377cb773512c6ef78d6eec57e6401d65262;hpb=34e63086edddcae06d7c1a4fa84fec0861e50758;p=openvswitch diff --git a/tests/test-stp.c b/tests/test-stp.c index c2a58377..fecada71 100644 --- a/tests/test-stp.c +++ b/tests/test-stp.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2010 Nicira Networks. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -14,6 +14,8 @@ * limitations under the License. */ +#include + #include "stp.h" #include #include @@ -241,7 +243,7 @@ dump_bridge_tree(struct test_case *tc, struct bridge *b, int level) } static void -dump_lan_tree(struct test_case *tc, struct lan *lan, int level) +dump_lan_tree(struct test_case *tc, struct lan *lan, int level) { int i; @@ -301,6 +303,7 @@ simulate(struct test_case *tc, int granularity) struct bpdu *bpdu = &b->rxq[b->rxq_tail % RXQ_SIZE]; stp_received_bpdu(stp_get_port(b->stp, bpdu->port_no), bpdu->data, bpdu->size); + free(bpdu->data); any = true; } } @@ -357,6 +360,7 @@ get_token(void) pos++; } if (*pos == '\0') { + free(token); token = NULL; return false; } @@ -501,8 +505,9 @@ main(int argc, char *argv[]) if (!strcmp(token, "0")) { lan = NULL; - } else if (strlen(token) == 1 && islower(*token)) { - lan = tc->lans[*token - 'a']; + } else if (strlen(token) == 1 + && islower((unsigned char)*token)) { + lan = tc->lans[*token - 'a']; } else { err("%s is not a valid LAN name " "(0 or a lowercase letter)", token); @@ -643,6 +648,19 @@ main(int argc, char *argv[]) err("trailing garbage on line"); } } + free(token); + + for (i = 0; i < tc->n_lans; i++) { + struct lan *lan = tc->lans[i]; + free((char *) lan->name); + free(lan); + } + for (i = 0; i < tc->n_bridges; i++) { + struct bridge *bridge = tc->bridges[i]; + stp_destroy(bridge->stp); + free(bridge); + } + free(tc); return 0; }