utils.c revision 662887c052f0fcd98287e2a7fa5843a4f66ca256
144d362409d5469aed47d19e7908d19bd194493aThomas Graf/*
244d362409d5469aed47d19e7908d19bd194493aThomas Graf * lib/utils.c		Utility Functions
344d362409d5469aed47d19e7908d19bd194493aThomas Graf *
444d362409d5469aed47d19e7908d19bd194493aThomas Graf *	This library is free software; you can redistribute it and/or
544d362409d5469aed47d19e7908d19bd194493aThomas Graf *	modify it under the terms of the GNU Lesser General Public
644d362409d5469aed47d19e7908d19bd194493aThomas Graf *	License as published by the Free Software Foundation version 2.1
744d362409d5469aed47d19e7908d19bd194493aThomas Graf *	of the License.
844d362409d5469aed47d19e7908d19bd194493aThomas Graf *
944d362409d5469aed47d19e7908d19bd194493aThomas Graf * Copyright (c) 2003-2006 Thomas Graf <tgraf@suug.ch>
1044d362409d5469aed47d19e7908d19bd194493aThomas Graf */
1144d362409d5469aed47d19e7908d19bd194493aThomas Graf
1244d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
1344d362409d5469aed47d19e7908d19bd194493aThomas Graf * @defgroup utils Utilities
1444d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
1544d362409d5469aed47d19e7908d19bd194493aThomas Graf */
1644d362409d5469aed47d19e7908d19bd194493aThomas Graf
1744d362409d5469aed47d19e7908d19bd194493aThomas Graf#include <netlink-local.h>
1844d362409d5469aed47d19e7908d19bd194493aThomas Graf#include <netlink/netlink.h>
1944d362409d5469aed47d19e7908d19bd194493aThomas Graf#include <netlink/utils.h>
2044d362409d5469aed47d19e7908d19bd194493aThomas Graf#include <linux/socket.h>
2144d362409d5469aed47d19e7908d19bd194493aThomas Graf
2244d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
2344d362409d5469aed47d19e7908d19bd194493aThomas Graf * Debug level
2444d362409d5469aed47d19e7908d19bd194493aThomas Graf */
2544d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_debug = 0;
2644d362409d5469aed47d19e7908d19bd194493aThomas Graf
2744d362409d5469aed47d19e7908d19bd194493aThomas Grafstruct nl_dump_params nl_debug_dp = {
2844d362409d5469aed47d19e7908d19bd194493aThomas Graf	.dp_type = NL_DUMP_FULL,
2944d362409d5469aed47d19e7908d19bd194493aThomas Graf};
3044d362409d5469aed47d19e7908d19bd194493aThomas Graf
313c56ed5787481a06703ffb25561df3dd56b447bdThomas Grafstatic void __init nl_debug_init(void)
3244d362409d5469aed47d19e7908d19bd194493aThomas Graf{
333c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf	char *nldbg, *end;
343c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf
353c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf	if ((nldbg = getenv("NLDBG"))) {
363c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf		long level = strtol(nldbg, &end, 0);
373c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf		if (nldbg != end)
383c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf			nl_debug = level;
393c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf	}
403c56ed5787481a06703ffb25561df3dd56b447bdThomas Graf
4144d362409d5469aed47d19e7908d19bd194493aThomas Graf	nl_debug_dp.dp_fd = stderr;
4244d362409d5469aed47d19e7908d19bd194493aThomas Graf}
4344d362409d5469aed47d19e7908d19bd194493aThomas Graf
4444d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
4544d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Error Code Helpers
4644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
4744d362409d5469aed47d19e7908d19bd194493aThomas Graf */
4844d362409d5469aed47d19e7908d19bd194493aThomas Graf
4944d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic char *errbuf;
5044d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic int nlerrno;
5144d362409d5469aed47d19e7908d19bd194493aThomas Graf
5244d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @cond SKIP */
5344d362409d5469aed47d19e7908d19bd194493aThomas Grafint __nl_error(int err, const char *file, unsigned int line, const char *func,
5444d362409d5469aed47d19e7908d19bd194493aThomas Graf	       const char *fmt, ...)
5544d362409d5469aed47d19e7908d19bd194493aThomas Graf{
5644d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *user_err;
5744d362409d5469aed47d19e7908d19bd194493aThomas Graf	va_list args;
5844d362409d5469aed47d19e7908d19bd194493aThomas Graf
5944d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (errbuf) {
6044d362409d5469aed47d19e7908d19bd194493aThomas Graf		free(errbuf);
6144d362409d5469aed47d19e7908d19bd194493aThomas Graf		errbuf = NULL;
6244d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
6344d362409d5469aed47d19e7908d19bd194493aThomas Graf
6444d362409d5469aed47d19e7908d19bd194493aThomas Graf	nlerrno = err;
6544d362409d5469aed47d19e7908d19bd194493aThomas Graf
6644d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (fmt) {
6744d362409d5469aed47d19e7908d19bd194493aThomas Graf		va_start(args, fmt);
6844d362409d5469aed47d19e7908d19bd194493aThomas Graf		vasprintf(&user_err, fmt, args);
6944d362409d5469aed47d19e7908d19bd194493aThomas Graf		va_end(args);
7044d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
7144d362409d5469aed47d19e7908d19bd194493aThomas Graf
7244d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef VERBOSE_ERRORS
7344d362409d5469aed47d19e7908d19bd194493aThomas Graf	asprintf(&errbuf, "%s:%u:%s: %s (errno = %s)",
7444d362409d5469aed47d19e7908d19bd194493aThomas Graf		 file, line, func, fmt ? user_err : "", strerror(err));
7544d362409d5469aed47d19e7908d19bd194493aThomas Graf#else
7644d362409d5469aed47d19e7908d19bd194493aThomas Graf	asprintf(&errbuf, "%s (errno = %s)",
7744d362409d5469aed47d19e7908d19bd194493aThomas Graf		 fmt ? user_err : "", strerror(err));
7844d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
7944d362409d5469aed47d19e7908d19bd194493aThomas Graf
8044d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (fmt)
8144d362409d5469aed47d19e7908d19bd194493aThomas Graf		free(user_err);
8244d362409d5469aed47d19e7908d19bd194493aThomas Graf
8344d362409d5469aed47d19e7908d19bd194493aThomas Graf	return -err;
8444d362409d5469aed47d19e7908d19bd194493aThomas Graf}
8544d362409d5469aed47d19e7908d19bd194493aThomas Graf
8644d362409d5469aed47d19e7908d19bd194493aThomas Grafint __nl_read_num_str_file(const char *path, int (*cb)(long, const char *))
8744d362409d5469aed47d19e7908d19bd194493aThomas Graf{
8844d362409d5469aed47d19e7908d19bd194493aThomas Graf	FILE *fd;
8944d362409d5469aed47d19e7908d19bd194493aThomas Graf	char buf[128];
9044d362409d5469aed47d19e7908d19bd194493aThomas Graf
9144d362409d5469aed47d19e7908d19bd194493aThomas Graf	fd = fopen(path, "r");
9244d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (fd == NULL)
9344d362409d5469aed47d19e7908d19bd194493aThomas Graf		return nl_error(errno, "Unable to open file %s for reading",
9444d362409d5469aed47d19e7908d19bd194493aThomas Graf				path);
9544d362409d5469aed47d19e7908d19bd194493aThomas Graf
9644d362409d5469aed47d19e7908d19bd194493aThomas Graf	while (fgets(buf, sizeof(buf), fd)) {
9744d362409d5469aed47d19e7908d19bd194493aThomas Graf		int goodlen, err;
9844d362409d5469aed47d19e7908d19bd194493aThomas Graf		long num;
9944d362409d5469aed47d19e7908d19bd194493aThomas Graf		char *end;
10044d362409d5469aed47d19e7908d19bd194493aThomas Graf
10144d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (*buf == '#' || *buf == '\n' || *buf == '\r')
10244d362409d5469aed47d19e7908d19bd194493aThomas Graf			continue;
10344d362409d5469aed47d19e7908d19bd194493aThomas Graf
10444d362409d5469aed47d19e7908d19bd194493aThomas Graf		num = strtol(buf, &end, 0);
10544d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (end == buf)
10644d362409d5469aed47d19e7908d19bd194493aThomas Graf			return nl_error(EINVAL, "Parsing error");
10744d362409d5469aed47d19e7908d19bd194493aThomas Graf
10844d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (num == LONG_MIN || num == LONG_MAX)
10944d362409d5469aed47d19e7908d19bd194493aThomas Graf			return nl_error(errno, "Number of out range");
11044d362409d5469aed47d19e7908d19bd194493aThomas Graf
11144d362409d5469aed47d19e7908d19bd194493aThomas Graf		while (*end == ' ' || *end == '\t')
11244d362409d5469aed47d19e7908d19bd194493aThomas Graf			end++;
11344d362409d5469aed47d19e7908d19bd194493aThomas Graf
11444d362409d5469aed47d19e7908d19bd194493aThomas Graf		goodlen = strcspn(end, "#\r\n\t ");
11544d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (goodlen == 0)
11644d362409d5469aed47d19e7908d19bd194493aThomas Graf			return nl_error(EINVAL, "Empty string");
11744d362409d5469aed47d19e7908d19bd194493aThomas Graf
11844d362409d5469aed47d19e7908d19bd194493aThomas Graf		end[goodlen] = '\0';
11944d362409d5469aed47d19e7908d19bd194493aThomas Graf
12044d362409d5469aed47d19e7908d19bd194493aThomas Graf		err = cb(num, end);
12144d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (err < 0)
12244d362409d5469aed47d19e7908d19bd194493aThomas Graf			return err;
12344d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
12444d362409d5469aed47d19e7908d19bd194493aThomas Graf
12544d362409d5469aed47d19e7908d19bd194493aThomas Graf	fclose(fd);
12644d362409d5469aed47d19e7908d19bd194493aThomas Graf
12744d362409d5469aed47d19e7908d19bd194493aThomas Graf	return 0;
12844d362409d5469aed47d19e7908d19bd194493aThomas Graf}
12944d362409d5469aed47d19e7908d19bd194493aThomas Graf
13044d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @endcond */
13144d362409d5469aed47d19e7908d19bd194493aThomas Graf
13244d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_get_errno(void)
13344d362409d5469aed47d19e7908d19bd194493aThomas Graf{
13444d362409d5469aed47d19e7908d19bd194493aThomas Graf	return nlerrno;
13544d362409d5469aed47d19e7908d19bd194493aThomas Graf}
13644d362409d5469aed47d19e7908d19bd194493aThomas Graf
13744d362409d5469aed47d19e7908d19bd194493aThomas Graf
13844d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
13944d362409d5469aed47d19e7908d19bd194493aThomas Graf * Return error message for an error code
14044d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return error message
14144d362409d5469aed47d19e7908d19bd194493aThomas Graf */
14244d362409d5469aed47d19e7908d19bd194493aThomas Grafchar *nl_geterror(void)
14344d362409d5469aed47d19e7908d19bd194493aThomas Graf{
14444d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (errbuf)
14544d362409d5469aed47d19e7908d19bd194493aThomas Graf		return errbuf;
14644d362409d5469aed47d19e7908d19bd194493aThomas Graf
14744d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (nlerrno)
14844d362409d5469aed47d19e7908d19bd194493aThomas Graf		return strerror(nlerrno);
14944d362409d5469aed47d19e7908d19bd194493aThomas Graf
150662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	return "Success\n";
15144d362409d5469aed47d19e7908d19bd194493aThomas Graf}
15244d362409d5469aed47d19e7908d19bd194493aThomas Graf
15344d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
15444d362409d5469aed47d19e7908d19bd194493aThomas Graf * Print a libnl error message
15544d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg s		error message prefix
15644d362409d5469aed47d19e7908d19bd194493aThomas Graf *
15744d362409d5469aed47d19e7908d19bd194493aThomas Graf * Prints the error message of the call that failed last.
15844d362409d5469aed47d19e7908d19bd194493aThomas Graf *
15944d362409d5469aed47d19e7908d19bd194493aThomas Graf * If s is not NULL and *s is not a null byte the argument
16044d362409d5469aed47d19e7908d19bd194493aThomas Graf * string is printed, followed by a colon and a blank. Then
16144d362409d5469aed47d19e7908d19bd194493aThomas Graf * the error message and a new-line.
16244d362409d5469aed47d19e7908d19bd194493aThomas Graf */
16344d362409d5469aed47d19e7908d19bd194493aThomas Grafvoid nl_perror(const char *s)
16444d362409d5469aed47d19e7908d19bd194493aThomas Graf{
16544d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (s && *s)
16644d362409d5469aed47d19e7908d19bd194493aThomas Graf		fprintf(stderr, "%s: %s\n", s, nl_geterror());
16744d362409d5469aed47d19e7908d19bd194493aThomas Graf	else
16844d362409d5469aed47d19e7908d19bd194493aThomas Graf		fprintf(stderr, "%s\n", nl_geterror());
16944d362409d5469aed47d19e7908d19bd194493aThomas Graf}
17044d362409d5469aed47d19e7908d19bd194493aThomas Graf
17144d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
17244d362409d5469aed47d19e7908d19bd194493aThomas Graf
17344d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
17444d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Unit Pretty-Printing
17544d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
17644d362409d5469aed47d19e7908d19bd194493aThomas Graf */
17744d362409d5469aed47d19e7908d19bd194493aThomas Graf
17844d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
17944d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancel down a byte counter
18044d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg	l		byte counter
18144d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg	unit		destination unit pointer
18244d362409d5469aed47d19e7908d19bd194493aThomas Graf *
18344d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancels down a byte counter until it reaches a reasonable
18444d362409d5469aed47d19e7908d19bd194493aThomas Graf * unit. The chosen unit is assigned to \a unit.
18544d362409d5469aed47d19e7908d19bd194493aThomas Graf *
18644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The cancelled down byte counter in the new unit.
18744d362409d5469aed47d19e7908d19bd194493aThomas Graf */
18844d362409d5469aed47d19e7908d19bd194493aThomas Grafdouble nl_cancel_down_bytes(unsigned long long l, char **unit)
18944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
19044d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (l >= 1099511627776LL) {
19144d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "TiB";
19244d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1099511627776LL;
19344d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1073741824) {
19444d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "GiB";
19544d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1073741824;
19644d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1048576) {
19744d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "MiB";
19844d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1048576;
19944d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1024) {
20044d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "KiB";
20144d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1024;
20244d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else {
20344d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "B";
20444d362409d5469aed47d19e7908d19bd194493aThomas Graf		return (double) l;
20544d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
20644d362409d5469aed47d19e7908d19bd194493aThomas Graf}
20744d362409d5469aed47d19e7908d19bd194493aThomas Graf
20844d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
20944d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancel down a bit counter
21044d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg	l		bit counter
21144d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg unit		destination unit pointer
21244d362409d5469aed47d19e7908d19bd194493aThomas Graf *
21344d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancels downa bit counter until it reaches a reasonable
21444d362409d5469aed47d19e7908d19bd194493aThomas Graf * unit. The chosen unit is assigned to \a unit.
21544d362409d5469aed47d19e7908d19bd194493aThomas Graf *
21644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The cancelled down bit counter in the new unit.
21744d362409d5469aed47d19e7908d19bd194493aThomas Graf */
21844d362409d5469aed47d19e7908d19bd194493aThomas Grafdouble nl_cancel_down_bits(unsigned long long l, char **unit)
21944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
22044d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (l >= 1099511627776ULL) {
22144d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "Tbit";
22244d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1099511627776ULL;
22344d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1073741824) {
22444d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "Gbit";
22544d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1073741824;
22644d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1048576) {
22744d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "Mbit";
22844d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1048576;
22944d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1024) {
23044d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "Kbit";
23144d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1024;
23244d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else {
23344d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "bit";
23444d362409d5469aed47d19e7908d19bd194493aThomas Graf		return (double) l;
23544d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
23644d362409d5469aed47d19e7908d19bd194493aThomas Graf
23744d362409d5469aed47d19e7908d19bd194493aThomas Graf}
23844d362409d5469aed47d19e7908d19bd194493aThomas Graf
23944d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
24044d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancel down a micro second value
24144d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg	l		micro seconds
24244d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg unit		destination unit pointer
24344d362409d5469aed47d19e7908d19bd194493aThomas Graf *
24444d362409d5469aed47d19e7908d19bd194493aThomas Graf * Cancels down a microsecond counter until it reaches a
24544d362409d5469aed47d19e7908d19bd194493aThomas Graf * reasonable unit. The chosen unit is assigned to \a unit.
24644d362409d5469aed47d19e7908d19bd194493aThomas Graf *
24744d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The cancelled down microsecond in the new unit
24844d362409d5469aed47d19e7908d19bd194493aThomas Graf */
24944d362409d5469aed47d19e7908d19bd194493aThomas Grafdouble nl_cancel_down_us(uint32_t l, char **unit)
25044d362409d5469aed47d19e7908d19bd194493aThomas Graf{
25144d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (l >= 1000000) {
25244d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "s";
25344d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1000000;
25444d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else if (l >= 1000) {
25544d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "ms";
25644d362409d5469aed47d19e7908d19bd194493aThomas Graf		return ((double) l) / 1000;
25744d362409d5469aed47d19e7908d19bd194493aThomas Graf	} else {
25844d362409d5469aed47d19e7908d19bd194493aThomas Graf		*unit = "us";
25944d362409d5469aed47d19e7908d19bd194493aThomas Graf		return (double) l;
26044d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
26144d362409d5469aed47d19e7908d19bd194493aThomas Graf}
26244d362409d5469aed47d19e7908d19bd194493aThomas Graf
26344d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
26444d362409d5469aed47d19e7908d19bd194493aThomas Graf
26544d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
26644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Generic Unit Translations
26744d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
26844d362409d5469aed47d19e7908d19bd194493aThomas Graf */
26944d362409d5469aed47d19e7908d19bd194493aThomas Graf
27044d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
27144d362409d5469aed47d19e7908d19bd194493aThomas Graf * Convert a character string to a size
27244d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg str		size encoded as character string
27344d362409d5469aed47d19e7908d19bd194493aThomas Graf *
27444d362409d5469aed47d19e7908d19bd194493aThomas Graf * Converts the specified size as character to the corresponding
27544d362409d5469aed47d19e7908d19bd194493aThomas Graf * number of bytes.
27644d362409d5469aed47d19e7908d19bd194493aThomas Graf *
27744d362409d5469aed47d19e7908d19bd194493aThomas Graf * Supported formats are:
27844d362409d5469aed47d19e7908d19bd194493aThomas Graf *  - b,kb/k,m/mb,gb/g for bytes
27944d362409d5469aed47d19e7908d19bd194493aThomas Graf *  - bit,kbit/mbit/gbit
28044d362409d5469aed47d19e7908d19bd194493aThomas Graf *
28144d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The number of bytes or -1 if the string is unparseable
28244d362409d5469aed47d19e7908d19bd194493aThomas Graf */
28344d362409d5469aed47d19e7908d19bd194493aThomas Graflong nl_size2int(const char *str)
28444d362409d5469aed47d19e7908d19bd194493aThomas Graf{
28544d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *p;
28644d362409d5469aed47d19e7908d19bd194493aThomas Graf	long l = strtol(str, &p, 0);
28744d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (p == str)
28844d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
28944d362409d5469aed47d19e7908d19bd194493aThomas Graf
29044d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (*p) {
29144d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (!strcasecmp(p, "kb") || !strcasecmp(p, "k"))
29244d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024;
29344d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "gb") || !strcasecmp(p, "g"))
29444d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024*1024*1024;
29544d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "gbit"))
29644d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024*1024*1024/8;
29744d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "mb") || !strcasecmp(p, "m"))
29844d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024*1024;
29944d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "mbit"))
30044d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024*1024/8;
30144d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "kbit"))
30244d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 1024/8;
30344d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "bit"))
30444d362409d5469aed47d19e7908d19bd194493aThomas Graf			l /= 8;
30544d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (strcasecmp(p, "b") != 0)
30644d362409d5469aed47d19e7908d19bd194493aThomas Graf			return -1;
30744d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
30844d362409d5469aed47d19e7908d19bd194493aThomas Graf
30944d362409d5469aed47d19e7908d19bd194493aThomas Graf	return l;
31044d362409d5469aed47d19e7908d19bd194493aThomas Graf}
31144d362409d5469aed47d19e7908d19bd194493aThomas Graf
31244d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
31344d362409d5469aed47d19e7908d19bd194493aThomas Graf * Convert a character string to a probability
31444d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg str		probability encoded as character string
31544d362409d5469aed47d19e7908d19bd194493aThomas Graf *
31644d362409d5469aed47d19e7908d19bd194493aThomas Graf * Converts the specified probability as character to the
31744d362409d5469aed47d19e7908d19bd194493aThomas Graf * corresponding probability number.
31844d362409d5469aed47d19e7908d19bd194493aThomas Graf *
31944d362409d5469aed47d19e7908d19bd194493aThomas Graf * Supported formats are:
32044d362409d5469aed47d19e7908d19bd194493aThomas Graf *  - 0.0-1.0
32144d362409d5469aed47d19e7908d19bd194493aThomas Graf *  - 0%-100%
32244d362409d5469aed47d19e7908d19bd194493aThomas Graf *
32344d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The probability relative to NL_PROB_MIN and NL_PROB_MAX
32444d362409d5469aed47d19e7908d19bd194493aThomas Graf */
32544d362409d5469aed47d19e7908d19bd194493aThomas Graflong nl_prob2int(const char *str)
32644d362409d5469aed47d19e7908d19bd194493aThomas Graf{
32744d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *p;
32844d362409d5469aed47d19e7908d19bd194493aThomas Graf	double d = strtod(str, &p);
32944d362409d5469aed47d19e7908d19bd194493aThomas Graf
33044d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (p == str)
33144d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
33244d362409d5469aed47d19e7908d19bd194493aThomas Graf
33344d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (d > 1.0)
33444d362409d5469aed47d19e7908d19bd194493aThomas Graf		d /= 100.0f;
33544d362409d5469aed47d19e7908d19bd194493aThomas Graf
33644d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (d > 1.0f || d < 0.0f)
33744d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
33844d362409d5469aed47d19e7908d19bd194493aThomas Graf
33944d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (*p && strcmp(p, "%") != 0)
34044d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
34144d362409d5469aed47d19e7908d19bd194493aThomas Graf
34244d362409d5469aed47d19e7908d19bd194493aThomas Graf	return rint(d * NL_PROB_MAX);
34344d362409d5469aed47d19e7908d19bd194493aThomas Graf}
34444d362409d5469aed47d19e7908d19bd194493aThomas Graf
34544d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
34644d362409d5469aed47d19e7908d19bd194493aThomas Graf
34744d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
34844d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Time Translations
34944d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
35044d362409d5469aed47d19e7908d19bd194493aThomas Graf */
35144d362409d5469aed47d19e7908d19bd194493aThomas Graf
35244d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef USER_HZ
35344d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic uint32_t user_hz = USER_HZ;
35444d362409d5469aed47d19e7908d19bd194493aThomas Graf#else
35544d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic uint32_t user_hz = 100;
35644d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
35744d362409d5469aed47d19e7908d19bd194493aThomas Graf
35844d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic double ticks_per_usec = 1.0f;
35944d362409d5469aed47d19e7908d19bd194493aThomas Graf
36044d362409d5469aed47d19e7908d19bd194493aThomas Graf/* Retrieves the configured HZ and ticks/us value in the kernel.
36144d362409d5469aed47d19e7908d19bd194493aThomas Graf * The value is cached. Supported ways of getting it:
36244d362409d5469aed47d19e7908d19bd194493aThomas Graf *
36344d362409d5469aed47d19e7908d19bd194493aThomas Graf * 1) environment variable
36444d362409d5469aed47d19e7908d19bd194493aThomas Graf * 2) /proc/net/psched and sysconf
36544d362409d5469aed47d19e7908d19bd194493aThomas Graf *
36644d362409d5469aed47d19e7908d19bd194493aThomas Graf * Supports the environment variables:
36744d362409d5469aed47d19e7908d19bd194493aThomas Graf *   PROC_NET_PSCHED  - may point to psched file in /proc
36844d362409d5469aed47d19e7908d19bd194493aThomas Graf *   PROC_ROOT        - may point to /proc fs */
36944d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic void __init get_psched_settings(void)
37044d362409d5469aed47d19e7908d19bd194493aThomas Graf{
37144d362409d5469aed47d19e7908d19bd194493aThomas Graf	char name[FILENAME_MAX];
37244d362409d5469aed47d19e7908d19bd194493aThomas Graf	FILE *fd;
37344d362409d5469aed47d19e7908d19bd194493aThomas Graf	int got_hz = 0, got_tick = 0;
37444d362409d5469aed47d19e7908d19bd194493aThomas Graf
37544d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (getenv("HZ")) {
37644d362409d5469aed47d19e7908d19bd194493aThomas Graf		long hz = strtol(getenv("HZ"), NULL, 0);
37744d362409d5469aed47d19e7908d19bd194493aThomas Graf
37844d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (LONG_MIN != hz && LONG_MAX != hz) {
37944d362409d5469aed47d19e7908d19bd194493aThomas Graf			user_hz = hz;
38044d362409d5469aed47d19e7908d19bd194493aThomas Graf			got_hz = 1;
38144d362409d5469aed47d19e7908d19bd194493aThomas Graf		}
38244d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
38344d362409d5469aed47d19e7908d19bd194493aThomas Graf
38444d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (!got_hz)
38544d362409d5469aed47d19e7908d19bd194493aThomas Graf		user_hz = sysconf(_SC_CLK_TCK);
38644d362409d5469aed47d19e7908d19bd194493aThomas Graf
38744d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (getenv("TICKS_PER_USEC")) {
38844d362409d5469aed47d19e7908d19bd194493aThomas Graf		double t = strtod(getenv("TICKS_PER_USEC"), NULL);
38944d362409d5469aed47d19e7908d19bd194493aThomas Graf
39044d362409d5469aed47d19e7908d19bd194493aThomas Graf		ticks_per_usec = t;
39144d362409d5469aed47d19e7908d19bd194493aThomas Graf		got_tick = 1;
39244d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
39344d362409d5469aed47d19e7908d19bd194493aThomas Graf
39444d362409d5469aed47d19e7908d19bd194493aThomas Graf
39544d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (getenv("PROC_NET_PSCHED"))
39644d362409d5469aed47d19e7908d19bd194493aThomas Graf		snprintf(name, sizeof(name), "%s", getenv("PROC_NET_PSCHED"));
39744d362409d5469aed47d19e7908d19bd194493aThomas Graf	else if (getenv("PROC_ROOT"))
39844d362409d5469aed47d19e7908d19bd194493aThomas Graf		snprintf(name, sizeof(name), "%s/net/psched",
39944d362409d5469aed47d19e7908d19bd194493aThomas Graf			 getenv("PROC_ROOT"));
40044d362409d5469aed47d19e7908d19bd194493aThomas Graf	else
40144d362409d5469aed47d19e7908d19bd194493aThomas Graf		strncpy(name, "/proc/net/psched", sizeof(name) - 1);
40244d362409d5469aed47d19e7908d19bd194493aThomas Graf
40344d362409d5469aed47d19e7908d19bd194493aThomas Graf	if ((fd = fopen(name, "r"))) {
40444d362409d5469aed47d19e7908d19bd194493aThomas Graf		uint32_t tick, us, nom;
40544d362409d5469aed47d19e7908d19bd194493aThomas Graf		int r = fscanf(fd, "%08x%08x%08x%*08x", &tick, &us, &nom);
40644d362409d5469aed47d19e7908d19bd194493aThomas Graf
40744d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (4 == r && nom == 1000000 && !got_tick)
40844d362409d5469aed47d19e7908d19bd194493aThomas Graf			ticks_per_usec = (double)tick/(double)us;
40944d362409d5469aed47d19e7908d19bd194493aThomas Graf
41044d362409d5469aed47d19e7908d19bd194493aThomas Graf		fclose(fd);
41144d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
41244d362409d5469aed47d19e7908d19bd194493aThomas Graf}
41344d362409d5469aed47d19e7908d19bd194493aThomas Graf
41444d362409d5469aed47d19e7908d19bd194493aThomas Graf
41544d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
41644d362409d5469aed47d19e7908d19bd194493aThomas Graf * Return the value of HZ
41744d362409d5469aed47d19e7908d19bd194493aThomas Graf */
41844d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_get_hz(void)
41944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
42044d362409d5469aed47d19e7908d19bd194493aThomas Graf	return user_hz;
42144d362409d5469aed47d19e7908d19bd194493aThomas Graf}
42244d362409d5469aed47d19e7908d19bd194493aThomas Graf
42344d362409d5469aed47d19e7908d19bd194493aThomas Graf
42444d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
42544d362409d5469aed47d19e7908d19bd194493aThomas Graf * Convert micro seconds to ticks
42644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg us		micro seconds
42744d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return number of ticks
42844d362409d5469aed47d19e7908d19bd194493aThomas Graf */
42944d362409d5469aed47d19e7908d19bd194493aThomas Grafuint32_t nl_us2ticks(uint32_t us)
43044d362409d5469aed47d19e7908d19bd194493aThomas Graf{
43144d362409d5469aed47d19e7908d19bd194493aThomas Graf	return us * ticks_per_usec;
43244d362409d5469aed47d19e7908d19bd194493aThomas Graf}
43344d362409d5469aed47d19e7908d19bd194493aThomas Graf
43444d362409d5469aed47d19e7908d19bd194493aThomas Graf
43544d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
43644d362409d5469aed47d19e7908d19bd194493aThomas Graf * Convert ticks to micro seconds
43744d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg ticks		number of ticks
43844d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return microseconds
43944d362409d5469aed47d19e7908d19bd194493aThomas Graf */
44044d362409d5469aed47d19e7908d19bd194493aThomas Grafuint32_t nl_ticks2us(uint32_t ticks)
44144d362409d5469aed47d19e7908d19bd194493aThomas Graf{
44244d362409d5469aed47d19e7908d19bd194493aThomas Graf	return ticks / ticks_per_usec;
44344d362409d5469aed47d19e7908d19bd194493aThomas Graf}
44444d362409d5469aed47d19e7908d19bd194493aThomas Graf
44544d362409d5469aed47d19e7908d19bd194493aThomas Graflong nl_time2int(const char *str)
44644d362409d5469aed47d19e7908d19bd194493aThomas Graf{
44744d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *p;
44844d362409d5469aed47d19e7908d19bd194493aThomas Graf	long l = strtol(str, &p, 0);
44944d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (p == str)
45044d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
45144d362409d5469aed47d19e7908d19bd194493aThomas Graf
45244d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (*p) {
45344d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (!strcasecmp(p, "min") == 0 || !strcasecmp(p, "m"))
45444d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 60;
45544d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "hour") || !strcasecmp(p, "h"))
45644d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 60*60;
45744d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (!strcasecmp(p, "day") || !strcasecmp(p, "d"))
45844d362409d5469aed47d19e7908d19bd194493aThomas Graf			l *= 60*60*24;
45944d362409d5469aed47d19e7908d19bd194493aThomas Graf		else if (strcasecmp(p, "s") != 0)
46044d362409d5469aed47d19e7908d19bd194493aThomas Graf			return -1;
46144d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
46244d362409d5469aed47d19e7908d19bd194493aThomas Graf
46344d362409d5469aed47d19e7908d19bd194493aThomas Graf	return l;
46444d362409d5469aed47d19e7908d19bd194493aThomas Graf}
46544d362409d5469aed47d19e7908d19bd194493aThomas Graf
46644d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
46744d362409d5469aed47d19e7908d19bd194493aThomas Graf * Convert milliseconds to a character string
46844d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg msec		number of milliseconds
46944d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg buf		destination buffer
47044d362409d5469aed47d19e7908d19bd194493aThomas Graf * @arg len		buffer length
47144d362409d5469aed47d19e7908d19bd194493aThomas Graf *
47244d362409d5469aed47d19e7908d19bd194493aThomas Graf * Converts milliseconds to a character string split up in days, hours,
47344d362409d5469aed47d19e7908d19bd194493aThomas Graf * minutes, seconds, and milliseconds and stores it in the specified
47444d362409d5469aed47d19e7908d19bd194493aThomas Graf * destination buffer.
47544d362409d5469aed47d19e7908d19bd194493aThomas Graf *
47644d362409d5469aed47d19e7908d19bd194493aThomas Graf * @return The destination buffer.
47744d362409d5469aed47d19e7908d19bd194493aThomas Graf */
47844d362409d5469aed47d19e7908d19bd194493aThomas Grafchar * nl_msec2str(uint64_t msec, char *buf, size_t len)
47944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
48044d362409d5469aed47d19e7908d19bd194493aThomas Graf	int i, split[5];
48144d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *units[] = {"d", "h", "m", "s", "msec"};
48244d362409d5469aed47d19e7908d19bd194493aThomas Graf
48344d362409d5469aed47d19e7908d19bd194493aThomas Graf#define _SPLIT(idx, unit) if ((split[idx] = msec / unit) > 0) msec %= unit
48444d362409d5469aed47d19e7908d19bd194493aThomas Graf	_SPLIT(0, 86400000);	/* days */
48544d362409d5469aed47d19e7908d19bd194493aThomas Graf	_SPLIT(1, 3600000);	/* hours */
48644d362409d5469aed47d19e7908d19bd194493aThomas Graf	_SPLIT(2, 60000);	/* minutes */
48744d362409d5469aed47d19e7908d19bd194493aThomas Graf	_SPLIT(3, 1000);	/* seconds */
48844d362409d5469aed47d19e7908d19bd194493aThomas Graf#undef  _SPLIT
48944d362409d5469aed47d19e7908d19bd194493aThomas Graf	split[4] = msec;
49044d362409d5469aed47d19e7908d19bd194493aThomas Graf
49144d362409d5469aed47d19e7908d19bd194493aThomas Graf	memset(buf, 0, len);
49244d362409d5469aed47d19e7908d19bd194493aThomas Graf
49344d362409d5469aed47d19e7908d19bd194493aThomas Graf	for (i = 0; i < ARRAY_SIZE(split); i++) {
49444d362409d5469aed47d19e7908d19bd194493aThomas Graf		if (split[i] > 0) {
49544d362409d5469aed47d19e7908d19bd194493aThomas Graf			char t[64];
49644d362409d5469aed47d19e7908d19bd194493aThomas Graf			snprintf(t, sizeof(t), "%s%d%s",
49744d362409d5469aed47d19e7908d19bd194493aThomas Graf				 strlen(buf) ? " " : "", split[i], units[i]);
49844d362409d5469aed47d19e7908d19bd194493aThomas Graf			strncat(buf, t, len - strlen(buf) - 1);
49944d362409d5469aed47d19e7908d19bd194493aThomas Graf		}
50044d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
50144d362409d5469aed47d19e7908d19bd194493aThomas Graf
50244d362409d5469aed47d19e7908d19bd194493aThomas Graf	return buf;
50344d362409d5469aed47d19e7908d19bd194493aThomas Graf}
50444d362409d5469aed47d19e7908d19bd194493aThomas Graf
50544d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
50644d362409d5469aed47d19e7908d19bd194493aThomas Graf
50744d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
50844d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Link Layer Protocol Translations
50944d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
51044d362409d5469aed47d19e7908d19bd194493aThomas Graf */
51144d362409d5469aed47d19e7908d19bd194493aThomas Graf
51244d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic struct trans_tbl llprotos[] = {
51344d362409d5469aed47d19e7908d19bd194493aThomas Graf	{0, "generic"},
51444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ETHER,ether)
51544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_EETHER,eether)
51644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_AX25,ax25)
51744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_PRONET,pronet)
51844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_CHAOS,chaos)
51944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IEEE802,ieee802)
52044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ARCNET,arcnet)
52144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_APPLETLK,atalk)
52244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_DLCI,dlci)
52344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ATM,atm)
52444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_METRICOM,metricom)
52544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IEEE1394,ieee1394)
52644d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ARPHRD_EUI64
52744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_EUI64,eui64)
52844d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
52944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_INFINIBAND,infiniband)
53044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_SLIP,slip)
53144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_CSLIP,cslip)
53244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_SLIP6,slip6)
53344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_CSLIP6,cslip6)
53444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_RSRVD,rsrvd)
53544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ADAPT,adapt)
53644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ROSE,rose)
53744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_X25,x25)
53844d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ARPHRD_HWX25
53944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_HWX25,hwx25)
54044d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
54144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_PPP,ppp)
54244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_HDLC,hdlc)
54344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_LAPB,lapb)
54444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_DDCMP,ddcmp)
54544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_RAWHDLC,rawhdlc)
54644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_TUNNEL,ipip)
54744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_TUNNEL6,tunnel6)
54844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FRAD,frad)
54944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_SKIP,skip)
55044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_LOOPBACK,loopback)
55144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_LOCALTLK,localtlk)
55244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FDDI,fddi)
55344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_BIF,bif)
55444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_SIT,sit)
55544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IPDDP,ip/ddp)
55644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IPGRE,gre)
55744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_PIMREG,pimreg)
55844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_HIPPI,hippi)
55944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ASH,ash)
56044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_ECONET,econet)
56144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IRDA,irda)
56244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCPP,fcpp)
56344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCAL,fcal)
56444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCPL,fcpl)
56544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC,fcfb_0)
56644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+1,fcfb_1)
56744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+2,fcfb_2)
56844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+3,fcfb_3)
56944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+4,fcfb_4)
57044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+5,fcfb_5)
57144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+6,fcfb_6)
57244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+7,fcfb_7)
57344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+8,fcfb_8)
57444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+9,fcfb_9)
57544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+10,fcfb_10)
57644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+11,fcfb_11)
57744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_FCFABRIC+12,fcfb_12)
57844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IEEE802_TR,tr)
57944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IEEE80211,ieee802.11)
58044d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ARPHRD_IEEE80211_PRISM
58144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_IEEE80211_PRISM, ieee802.11_prism)
58244d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
58344d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ARPHRD_VOID
58444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ARPHRD_VOID,void)
58544d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
58644d362409d5469aed47d19e7908d19bd194493aThomas Graf};
58744d362409d5469aed47d19e7908d19bd194493aThomas Graf
58844d362409d5469aed47d19e7908d19bd194493aThomas Grafchar * nl_llproto2str(int llproto, char *buf, size_t len)
58944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
59044d362409d5469aed47d19e7908d19bd194493aThomas Graf	return __type2str(llproto, buf, len, llprotos, ARRAY_SIZE(llprotos));
59144d362409d5469aed47d19e7908d19bd194493aThomas Graf}
59244d362409d5469aed47d19e7908d19bd194493aThomas Graf
59344d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_str2llproto(const char *name)
59444d362409d5469aed47d19e7908d19bd194493aThomas Graf{
59544d362409d5469aed47d19e7908d19bd194493aThomas Graf	return __str2type(name, llprotos, ARRAY_SIZE(llprotos));
59644d362409d5469aed47d19e7908d19bd194493aThomas Graf}
59744d362409d5469aed47d19e7908d19bd194493aThomas Graf
59844d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
59944d362409d5469aed47d19e7908d19bd194493aThomas Graf
60044d362409d5469aed47d19e7908d19bd194493aThomas Graf
60144d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
60244d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name Ethernet Protocol Translations
60344d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
60444d362409d5469aed47d19e7908d19bd194493aThomas Graf */
60544d362409d5469aed47d19e7908d19bd194493aThomas Graf
60644d362409d5469aed47d19e7908d19bd194493aThomas Grafstatic struct trans_tbl ether_protos[] = {
60744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_LOOP,loop)
60844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PUP,pup)
60944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PUPAT,pupat)
61044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IP,ip)
61144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_X25,x25)
61244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ARP,arp)
61344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_BPQ,bpq)
61444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IEEEPUP,ieeepup)
61544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IEEEPUPAT,ieeepupat)
61644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DEC,dec)
61744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DNA_DL,dna_dl)
61844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DNA_RC,dna_rc)
61944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DNA_RT,dna_rt)
62044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_LAT,lat)
62144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DIAG,diag)
62244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_CUST,cust)
62344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_SCA,sca)
62444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_RARP,rarp)
62544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ATALK,atalk)
62644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_AARP,aarp)
62744d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ETH_P_8021Q
62844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_8021Q,802.1q)
62944d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
63044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IPX,ipx)
63144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IPV6,ipv6)
63244d362409d5469aed47d19e7908d19bd194493aThomas Graf#ifdef ETH_P_WCCP
63344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_WCCP,wccp)
63444d362409d5469aed47d19e7908d19bd194493aThomas Graf#endif
63544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PPP_DISC,ppp_disc)
63644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PPP_SES,ppp_ses)
63744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_MPLS_UC,mpls_uc)
63844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_MPLS_MC,mpls_mc)
63944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ATMMPOA,atmmpoa)
64044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ATMFATE,atmfate)
64144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_EDP2,edp2)
64244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_802_3,802.3)
64344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_AX25,ax25)
64444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ALL,all)
64544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_802_2,802.2)
64644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_SNAP,snap)
64744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_DDCMP,ddcmp)
64844d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_WAN_PPP,wan_ppp)
64944d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PPP_MP,ppp_mp)
65044d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_LOCALTALK,localtalk)
65144d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_PPPTALK,ppptalk)
65244d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_TR_802_2,tr_802.2)
65344d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_MOBITEX,mobitex)
65444d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_CONTROL,control)
65544d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_IRDA,irda)
65644d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_ECONET,econet)
65744d362409d5469aed47d19e7908d19bd194493aThomas Graf	__ADD(ETH_P_HDLC,hdlc)
65844d362409d5469aed47d19e7908d19bd194493aThomas Graf};
65944d362409d5469aed47d19e7908d19bd194493aThomas Graf
66044d362409d5469aed47d19e7908d19bd194493aThomas Grafchar *nl_ether_proto2str(int eproto, char *buf, size_t len)
66144d362409d5469aed47d19e7908d19bd194493aThomas Graf{
66244d362409d5469aed47d19e7908d19bd194493aThomas Graf	return __type2str(eproto, buf, len, ether_protos,
66344d362409d5469aed47d19e7908d19bd194493aThomas Graf			    ARRAY_SIZE(ether_protos));
66444d362409d5469aed47d19e7908d19bd194493aThomas Graf}
66544d362409d5469aed47d19e7908d19bd194493aThomas Graf
66644d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_str2ether_proto(const char *name)
66744d362409d5469aed47d19e7908d19bd194493aThomas Graf{
66844d362409d5469aed47d19e7908d19bd194493aThomas Graf	return __str2type(name, ether_protos, ARRAY_SIZE(ether_protos));
66944d362409d5469aed47d19e7908d19bd194493aThomas Graf}
67044d362409d5469aed47d19e7908d19bd194493aThomas Graf
67144d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
67244d362409d5469aed47d19e7908d19bd194493aThomas Graf
67344d362409d5469aed47d19e7908d19bd194493aThomas Graf/**
67444d362409d5469aed47d19e7908d19bd194493aThomas Graf * @name IP Protocol Translations
67544d362409d5469aed47d19e7908d19bd194493aThomas Graf * @{
67644d362409d5469aed47d19e7908d19bd194493aThomas Graf */
67744d362409d5469aed47d19e7908d19bd194493aThomas Graf
67844d362409d5469aed47d19e7908d19bd194493aThomas Grafchar *nl_ip_proto2str(int proto, char *buf, size_t len)
67944d362409d5469aed47d19e7908d19bd194493aThomas Graf{
68044d362409d5469aed47d19e7908d19bd194493aThomas Graf	struct protoent *p = getprotobynumber(proto);
68144d362409d5469aed47d19e7908d19bd194493aThomas Graf
68244d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (p) {
68344d362409d5469aed47d19e7908d19bd194493aThomas Graf		snprintf(buf, len, "%s", p->p_name);
68444d362409d5469aed47d19e7908d19bd194493aThomas Graf		return buf;
68544d362409d5469aed47d19e7908d19bd194493aThomas Graf	}
68644d362409d5469aed47d19e7908d19bd194493aThomas Graf
68744d362409d5469aed47d19e7908d19bd194493aThomas Graf	snprintf(buf, len, "0x%x", proto);
68844d362409d5469aed47d19e7908d19bd194493aThomas Graf	return buf;
68944d362409d5469aed47d19e7908d19bd194493aThomas Graf}
69044d362409d5469aed47d19e7908d19bd194493aThomas Graf
69144d362409d5469aed47d19e7908d19bd194493aThomas Grafint nl_str2ip_proto(const char *name)
69244d362409d5469aed47d19e7908d19bd194493aThomas Graf{
69344d362409d5469aed47d19e7908d19bd194493aThomas Graf	struct protoent *p = getprotobyname(name);
69444d362409d5469aed47d19e7908d19bd194493aThomas Graf	unsigned long l;
69544d362409d5469aed47d19e7908d19bd194493aThomas Graf	char *end;
69644d362409d5469aed47d19e7908d19bd194493aThomas Graf
69744d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (p)
69844d362409d5469aed47d19e7908d19bd194493aThomas Graf		return p->p_proto;
69944d362409d5469aed47d19e7908d19bd194493aThomas Graf
70044d362409d5469aed47d19e7908d19bd194493aThomas Graf	l = strtoul(name, &end, 0);
70144d362409d5469aed47d19e7908d19bd194493aThomas Graf	if (l == ULONG_MAX || *end != '\0')
70244d362409d5469aed47d19e7908d19bd194493aThomas Graf		return -1;
70344d362409d5469aed47d19e7908d19bd194493aThomas Graf
70444d362409d5469aed47d19e7908d19bd194493aThomas Graf	return (int) l;
70544d362409d5469aed47d19e7908d19bd194493aThomas Graf}
70644d362409d5469aed47d19e7908d19bd194493aThomas Graf
70744d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
70844d362409d5469aed47d19e7908d19bd194493aThomas Graf
709508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf/**
710508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @name Dumping Helpers
711508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @{
712508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf */
713508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
714508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf/**
715508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * Handle a new line while dumping
716508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @arg params		Dumping parameters
717508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf *
718508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * This function must be called before dumping any onto a
719508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * new line. It will ensure proper prefixing as specified
720508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * by the dumping parameters.
721508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf *
722508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @note This function will NOT dump any newlines itself
723508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf */
724662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Grafvoid nl_new_line(struct nl_dump_params *params)
725508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf{
726662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	params->dp_line++;
727662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf
728508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	if (params->dp_prefix) {
729508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf		int i;
730508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf		for (i = 0; i < params->dp_prefix; i++) {
731508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf			if (params->dp_fd)
732508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf				fprintf(params->dp_fd, " ");
733508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf			else if (params->dp_buf)
734508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf				strncat(params->dp_buf, " ",
735508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf					params->dp_buflen -
736508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf					sizeof(params->dp_buf) - 1);
737508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf		}
738508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	}
739508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
740508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	if (params->dp_nl_cb)
741662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf		params->dp_nl_cb(params, params->dp_line);
742508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf}
743508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
744508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf/**
745508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * Dump a formatted character string
746508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @arg params		Dumping parameters
747508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @arg fmt		printf style formatting string
748508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * @arg ...		Arguments to formatting string
749508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf *
750508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * Dumps a printf style formatting string to the output device
751508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf * as specified by the dumping parameters.
752508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf */
753508685c269275cb7ba3471c75abc689b4e3839b1Thomas Grafvoid nl_dump(struct nl_dump_params *params, const char *fmt, ...)
754508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf{
755508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	va_list args;
756508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
757508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	va_start(args, fmt);
758508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	__dp_dump(params, fmt, args);
759508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf	va_end(args);
760508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf}
761508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
762662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Grafvoid nl_dump_line(struct nl_dump_params *parms, const char *fmt, ...)
763662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf{
764662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	va_list args;
765662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf
766662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	nl_new_line(parms);
767662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf
768662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	va_start(args, fmt);
769662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	__dp_dump(parms, fmt, args);
770662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf	va_end(args);
771662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf}
772662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf
773662887c052f0fcd98287e2a7fa5843a4f66ca256Thomas Graf
774508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf/** @} */
775508685c269275cb7ba3471c75abc689b4e3839b1Thomas Graf
77644d362409d5469aed47d19e7908d19bd194493aThomas Graf/** @} */
777