Page MenuHomeFreeBSD

D5157.1778284787.diff
No OneTemporary

Size
942 B
Referenced Files
None
Subscribers
None

D5157.1778284787.diff

Index: sys/netinet6/ip6_output.c
===================================================================
--- sys/netinet6/ip6_output.c
+++ sys/netinet6/ip6_output.c
@@ -1372,6 +1372,15 @@
int retval;
#endif
+/*
+ * Don't use more than a quarter of mbuf clusters. N.B.:
+ * nmbclusters is an int, but nmbclusters * MCLBYTES may overflow
+ * on LP64 architectures, so cast to u_long to avoid undefined
+ * behavior. ILP32 architectures cannot have nmbclusters
+ * large enough to overflow for other reasons.
+ */
+#define IPV6_PKTOPTIONS_MBUF_LIMIT ((u_long)nmbclusters * MCLBYTES / 4)
+
level = sopt->sopt_level;
op = sopt->sopt_dir;
optname = sopt->sopt_name;
@@ -1427,6 +1436,12 @@
{
struct mbuf *m;
+ if (optlen > IPV6_PKTOPTIONS_MBUF_LIMIT) {
+ printf("ip6_ctloutput: mbuf limit hit\n");
+ error = ENOBUFS;
+ break;
+ }
+
error = soopt_getm(sopt, &m); /* XXX */
if (error != 0)
break;

File Metadata

Mime Type
text/plain
Expires
Fri, May 8, 11:59 PM (12 h, 22 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
28615203
Default Alt Text
D5157.1778284787.diff (942 B)

Event Timeline