[CRIU] [PATCH v7 08/15] zdtm/net/ipv4: make save_and_set and check_and_restore reusable

Pavel Tikhomirov ptikhomirov at virtuozzo.com
Thu Apr 28 09:38:56 PDT 2016


Get arrays out of save_and_set and check_and_restore, as it is an
overkill to give to the function wich should work with only one
element of array the whole array.

These makes them reusable in future test of ipv6 config.

https://jira.sw.ru/browse/PSBM-30942

Signed-off-by: Pavel Tikhomirov <ptikhomirov at virtuozzo.com>
---
 test/zdtm/static/netns-dev.c | 29 ++++++++++++++++-------------
 1 file changed, 16 insertions(+), 13 deletions(-)

diff --git a/test/zdtm/static/netns-dev.c b/test/zdtm/static/netns-dev.c
index 14c77be..fbde523 100644
--- a/test/zdtm/static/netns-dev.c
+++ b/test/zdtm/static/netns-dev.c
@@ -82,14 +82,15 @@ struct test_conf {
 	char *dir4;
 } lo, def;
 
-static int save_and_set(int opt, FILE *fp, struct test_conf *tc) {
+static int save_and_set(FILE *fp, int *conf, int *conf_rand,
+		int rand_limit, char *path) {
 	int ret;
 	int val;
 
 	/*
 	 * Save
 	 */
-	ret = fscanf(fp, "%d", &tc->ipv4_conf[opt]);
+	ret = fscanf(fp, "%d", conf);
 	if (ret != 1) {
 		pr_perror("fscanf");
 		return -1;
@@ -106,12 +107,12 @@ static int save_and_set(int opt, FILE *fp, struct test_conf *tc) {
 	 */
 	val = (int)lrand48();
 
-	if (rand_limit4[opt] != 0)
-		tc->ipv4_conf_rand[opt] = val % rand_limit4[opt];
+	if (rand_limit != 0)
+		*conf_rand = val % rand_limit;
 	else
-		tc->ipv4_conf_rand[opt] = val;
+		*conf_rand = val;
 
-	ret = fprintf(fp, "%d", tc->ipv4_conf_rand[opt]);
+	ret = fprintf(fp, "%d", *conf_rand);
 	if (ret < 0) {
 		pr_perror("fprintf");
 		return -1;
@@ -120,7 +121,8 @@ static int save_and_set(int opt, FILE *fp, struct test_conf *tc) {
 	return 0;
 }
 
-static int check_and_restore(int opt, FILE *fp, struct test_conf *tc) {
+static int check_and_restore(FILE *fp, int *conf, int *conf_rand,
+		int rand_limit, char *path) {
 	int ret;
 	int val;
 
@@ -133,9 +135,9 @@ static int check_and_restore(int opt, FILE *fp, struct test_conf *tc) {
 		return -1;
 	}
 
-	if (val != tc->ipv4_conf_rand[opt]) {
-		fail("Option \"%s/%s\" changed from %d to %d",
-		     tc->dir4, devconfs4[opt], tc->ipv4_conf_rand[opt], val);
+	if (val != *conf_rand) {
+		fail("Option \"%s\" changed from %d to %d",
+		     path, *conf_rand, val);
 		return -1;
 	}
 
@@ -148,7 +150,7 @@ static int check_and_restore(int opt, FILE *fp, struct test_conf *tc) {
 	/*
 	 * Restore opt
 	 */
-	ret = fprintf(fp, "%d", tc->ipv4_conf[opt]);
+	ret = fprintf(fp, "%d", *conf);
 	if (ret < 0) {
 		pr_perror("fprintf");
 		return -1;
@@ -157,7 +159,8 @@ static int check_and_restore(int opt, FILE *fp, struct test_conf *tc) {
 	return 0;
 }
 
-static int for_each_option_do(int (*f)(int opt, FILE *fp, struct test_conf *tc), struct test_conf *tc) {
+static int for_each_option_do(int (*f)(FILE *fp, int *conf, int *conf_rand,
+			int rand_limit, char *path), struct test_conf *tc) {
 	int ret;
 	int i;
 
@@ -181,7 +184,7 @@ static int for_each_option_do(int (*f)(int opt, FILE *fp, struct test_conf *tc),
 			return -1;
 		}
 
-		ret = (*f)(i, fp, tc);
+		ret = (*f)(fp, &tc->ipv4_conf[i], &tc->ipv4_conf_rand[i], rand_limit4[i], path);
 		if (ret < 0)
 			return -1;
 
-- 
2.5.5



More information about the CRIU mailing list