Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/net Don't use the stack, print to the buffer directly (t...
details: https://anonhg.NetBSD.org/src/rev/f44e0ed1091b
branches: trunk
changeset: 379322:f44e0ed1091b
user: christos <christos%NetBSD.org@localhost>
date: Thu May 27 13:36:33 2021 +0000
description:
Don't use the stack, print to the buffer directly (this was one of the
biggest stack users).
diffstat:
sys/net/dl_print.c | 60 +++++++++++++++++++++++++++++++++++++++--------------
1 files changed, 44 insertions(+), 16 deletions(-)
diffs (115 lines):
diff -r 67b4cf948fdf -r f44e0ed1091b sys/net/dl_print.c
--- a/sys/net/dl_print.c Thu May 27 13:32:54 2021 +0000
+++ b/sys/net/dl_print.c Thu May 27 13:36:33 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dl_print.c,v 1.6 2019/04/30 20:56:32 kre Exp $ */
+/* $NetBSD: dl_print.c,v 1.7 2021/05/27 13:36:33 christos Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -29,17 +29,17 @@
#include <sys/types.h>
#ifdef _KERNEL
-__KERNEL_RCSID(0, "$NetBSD: dl_print.c,v 1.6 2019/04/30 20:56:32 kre Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dl_print.c,v 1.7 2021/05/27 13:36:33 christos Exp $");
#include <sys/systm.h>
#else
-__RCSID("$NetBSD: dl_print.c,v 1.6 2019/04/30 20:56:32 kre Exp $");
+__RCSID("$NetBSD: dl_print.c,v 1.7 2021/05/27 13:36:33 christos Exp $");
#include <stdio.h>
static const char hexdigits[] = "0123456789abcdef";
#endif
#include <net/if_dl.h>
-char *
-lla_snprintf(char *dst, size_t dst_len, const void *src, size_t src_len)
+static int
+lla_snprintf1(char *dst, size_t dst_len, const void *src, size_t src_len)
{
char *dp;
const uint8_t *sp, *ep;
@@ -47,44 +47,72 @@ lla_snprintf(char *dst, size_t dst_len,
if (src_len == 0 || dst_len < 3) {
if (dst_len != 0)
dst[0] = '\0';
- return NULL;
+ return src_len ? (int)(src_len * 3) - 1 : 0;
}
dp = dst;
sp = (const uint8_t *)src;
ep = sp + src_len;
while (sp < ep) {
- if (dst_len < 3)
+ if (dst_len-- == 0)
break;
- dst_len -= 3;
*dp++ = hexdigits[(*sp) >> 4];
+ if (dst_len-- == 0)
+ break;
*dp++ = hexdigits[(*sp++) & 0xf];
+ if (dst_len-- == 0)
+ break;
*dp++ = ':';
}
- *--dp = 0;
+ *--dp = '\0';
+
+ return (int)(src_len * 3) - 1;
+}
+char *
+lla_snprintf(char *dst, size_t dst_len, const void *src, size_t src_len)
+{
+ if (lla_snprintf1(dst, dst_len, src, src_len) == -1)
+ return NULL;
return dst;
}
+#define clip(a, b) ((a) > (size_t)(b) ? (a) - (size_t)(b) : 0)
+
int
dl_print(char *buf, size_t len, const struct dl_addr *dl)
{
- char abuf[256 * 3];
+ int l = snprintf(buf, len, "%.*s/%hhu#",
+ (int)dl->dl_nlen, dl->dl_data, dl->dl_type);
+ if (l == -1)
+ return l;
+ int ll = lla_snprintf1(buf + l, clip(len, l),
+ dl->dl_data + dl->dl_nlen, dl->dl_alen);
+ if (ll == -1)
+ return ll;
- lla_snprintf(abuf, sizeof(abuf), dl->dl_data+dl->dl_nlen, dl->dl_alen);
- return snprintf(buf, len, "%.*s/%hhu#%s",
- (int)dl->dl_nlen, dl->dl_data, dl->dl_type, abuf);
+ return ll + l;
}
int
sdl_print(char *buf, size_t len, const void *v)
{
const struct sockaddr_dl *sdl = v;
- char abuf[LINK_ADDRSTRLEN];
if (sdl->sdl_slen == 0 && sdl->sdl_nlen == 0 && sdl->sdl_alen == 0)
return snprintf(buf, len, "link#%hu", sdl->sdl_index);
- dl_print(abuf, sizeof(abuf), &sdl->sdl_addr);
- return snprintf(buf, len, "[%s]:%hu", abuf, sdl->sdl_index);
+ if (len > 0) {
+ buf[0] = '[';
+ len--;
+ }
+ int l = dl_print(buf + 1, len, &sdl->sdl_addr);
+ if (l == -1)
+ return l;
+ l++;
+ len++;
+ int ll = snprintf(buf + l, clip(len, l), "]:%hu", sdl->sdl_index);
+ if (ll == -1)
+ return ll;
+ return ll + l;
}
Home |
Main Index |
Thread Index |
Old Index