mirror of
				https://git.proxmox.com/git/mirror_iproute2
				synced 2025-10-31 12:21:10 +00:00 
			
		
		
		
	ip link: add json support for tun attributes
Reported-by: Stephen Hemminger <stephen@networkplumber.org>
Fixes: 118eda77d6 ("ip link: add support to display extended tun attributes")
Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Reviewed-by: Stefano Brivio <sbrivio@redhat.com>
Signed-off-by: David Ahern <dsahern@gmail.com>
			
			
This commit is contained in:
		
							parent
							
								
									f798a8ab52
								
							
						
					
					
						commit
						7ba0a77b7e
					
				| @ -475,9 +475,9 @@ static void print_owner(FILE *f, uid_t uid) | ||||
| 	struct passwd *pw = getpwuid(uid); | ||||
| 
 | ||||
| 	if (pw) | ||||
| 		fprintf(f, "user %s ", pw->pw_name); | ||||
| 		print_string(PRINT_ANY, "user", "user %s ", pw->pw_name); | ||||
| 	else | ||||
| 		fprintf(f, "user %u ", uid); | ||||
| 		print_uint(PRINT_ANY, "user", "user %u ", uid); | ||||
| } | ||||
| 
 | ||||
| static void print_group(FILE *f, gid_t gid) | ||||
| @ -485,33 +485,54 @@ static void print_group(FILE *f, gid_t gid) | ||||
| 	struct group *group = getgrgid(gid); | ||||
| 
 | ||||
| 	if (group) | ||||
| 		fprintf(f, "group %s ", group->gr_name); | ||||
| 		print_string(PRINT_ANY, "group", "group %s ", group->gr_name); | ||||
| 	else | ||||
| 		fprintf(f, "group %u ", gid); | ||||
| 		print_uint(PRINT_ANY, "group", "group %u ", gid); | ||||
| } | ||||
| 
 | ||||
| static void print_mq(FILE *f, struct rtattr *tb[]) | ||||
| { | ||||
| 	if (!tb[IFLA_TUN_MULTI_QUEUE] || | ||||
| 	    !rta_getattr_u8(tb[IFLA_TUN_MULTI_QUEUE])) | ||||
| 	    !rta_getattr_u8(tb[IFLA_TUN_MULTI_QUEUE])) { | ||||
| 		if (is_json_context()) | ||||
| 			print_bool(PRINT_JSON, "multi_queue", NULL, false); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| 	fprintf(f, "multi_queue "); | ||||
| 	print_bool(PRINT_ANY, "multi_queue", "multi_queue ", true); | ||||
| 
 | ||||
| 	if (tb[IFLA_TUN_NUM_QUEUES]) { | ||||
| 		fprintf(f, "numqueues %u ", | ||||
| 			rta_getattr_u32(tb[IFLA_TUN_NUM_QUEUES])); | ||||
| 		print_uint(PRINT_ANY, "numqueues", "numqueues %u ", | ||||
| 			   rta_getattr_u32(tb[IFLA_TUN_NUM_QUEUES])); | ||||
| 	} | ||||
| 
 | ||||
| 	if (tb[IFLA_TUN_NUM_DISABLED_QUEUES]) { | ||||
| 		fprintf(f, "numdisabled %u ", | ||||
| 			rta_getattr_u32(tb[IFLA_TUN_NUM_DISABLED_QUEUES])); | ||||
| 		print_uint(PRINT_ANY, "numdisabled", "numdisabled %u ", | ||||
| 			   rta_getattr_u32(tb[IFLA_TUN_NUM_DISABLED_QUEUES])); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void print_onoff(FILE *f, const char *flag, __u8 val) | ||||
| { | ||||
| 	fprintf(f, "%s %s ", flag, val ? "on" : "off"); | ||||
| 	if (is_json_context()) | ||||
| 		print_bool(PRINT_JSON, flag, NULL, !!val); | ||||
| 	else | ||||
| 		fprintf(f, "%s %s ", flag, val ? "on" : "off"); | ||||
| } | ||||
| 
 | ||||
| static void print_type(FILE *f, __u8 type) | ||||
| { | ||||
| 	SPRINT_BUF(buf); | ||||
| 	const char *str = buf; | ||||
| 
 | ||||
| 	if (type == IFF_TUN) | ||||
| 		str = "tun"; | ||||
| 	else if (type == IFF_TAP) | ||||
| 		str = "tap"; | ||||
| 	else | ||||
| 		snprintf(buf, sizeof(buf), "UNKNOWN:%hhu", type); | ||||
| 
 | ||||
| 	print_string(PRINT_ANY, "type", "type %s ", str); | ||||
| } | ||||
| 
 | ||||
| static void tun_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[]) | ||||
| @ -519,16 +540,8 @@ static void tun_print_opt(struct link_util *lu, FILE *f, struct rtattr *tb[]) | ||||
| 	if (!tb) | ||||
| 		return; | ||||
| 
 | ||||
| 	if (tb[IFLA_TUN_TYPE]) { | ||||
| 		__u8 type = rta_getattr_u8(tb[IFLA_TUN_TYPE]); | ||||
| 
 | ||||
| 		if (type == IFF_TUN) | ||||
| 			fprintf(f, "type tun "); | ||||
| 		else if (type == IFF_TAP) | ||||
| 			fprintf(f, "type tap "); | ||||
| 		else | ||||
| 			fprintf(f, "type UNKNOWN:%hhu ", type); | ||||
| 	} | ||||
| 	if (tb[IFLA_TUN_TYPE]) | ||||
| 		print_type(f, rta_getattr_u8(tb[IFLA_TUN_TYPE])); | ||||
| 
 | ||||
| 	if (tb[IFLA_TUN_PI]) | ||||
| 		print_onoff(f, "pi", rta_getattr_u8(tb[IFLA_TUN_PI])); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Sabrina Dubroca
						Sabrina Dubroca