aboutsummaryrefslogtreecommitdiff
path: root/resolv
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2021-07-19 07:55:27 +0200
committerFlorian Weimer <fweimer@redhat.com>2021-07-19 07:56:21 +0200
commit13e1f86706e463de4429f7e88f47c6ff65cd845e (patch)
treecd309d16de42acae7b2d688dbdd53f3603b135a5 /resolv
parent7ed1ac6da3d6ae5bfbbf4c4bdce07a40e8113df8 (diff)
downloadglibc-13e1f86706e463de4429f7e88f47c6ff65cd845e.zip
glibc-13e1f86706e463de4429f7e88f47c6ff65cd845e.tar.gz
glibc-13e1f86706e463de4429f7e88f47c6ff65cd845e.tar.bz2
resolv: Move ns_name_compress into its own file and into libc
And reformat to GNU style. The symbol was moved using scripts/move-symbol-to-libc.py. Reviewed-by: Carlos O'Donell <carlos@redhat.com> Tested-by: Carlos O'Donell <carlos@redhat.com>
Diffstat (limited to 'resolv')
-rw-r--r--resolv/Makefile1
-rw-r--r--resolv/Versions4
-rw-r--r--resolv/ns_name.c27
-rw-r--r--resolv/ns_name_compress.c50
4 files changed, 54 insertions, 28 deletions
diff --git a/resolv/Makefile b/resolv/Makefile
index 8bb2585..64600ab 100644
--- a/resolv/Makefile
+++ b/resolv/Makefile
@@ -32,6 +32,7 @@ routines := \
inet_addr \
inet_ntop \
inet_pton \
+ ns_name_compress \
ns_name_ntop \
ns_name_pack \
ns_name_pton \
diff --git a/resolv/Versions b/resolv/Versions
index 8ea42da..a676be2 100644
--- a/resolv/Versions
+++ b/resolv/Versions
@@ -25,6 +25,7 @@ libc {
%endif
}
GLIBC_2.9 {
+ ns_name_compress;
ns_name_ntop;
ns_name_pack;
ns_name_pton;
@@ -39,6 +40,7 @@ libc {
gai_suspend;
getaddrinfo_a;
%endif
+ ns_name_compress;
ns_name_ntop;
ns_name_pack;
ns_name_pton;
@@ -53,6 +55,7 @@ libc {
__h_errno;
__inet_aton_exact;
__inet_pton_length;
+ __ns_name_compress;
__ns_name_ntop;
__ns_name_pack;
__ns_name_pton;
@@ -155,7 +158,6 @@ libresolv {
ns_initparse;
ns_makecanon;
ns_msg_getflag;
- ns_name_compress;
ns_name_ntol;
ns_name_pton;
ns_name_rollback;
diff --git a/resolv/ns_name.c b/resolv/ns_name.c
index f1a84ad..f19c11c 100644
--- a/resolv/ns_name.c
+++ b/resolv/ns_name.c
@@ -90,33 +90,6 @@ ns_name_ntol(const u_char *src, u_char *dst, size_t dstsiz)
}
/*%
- * Compress a domain name into wire format, using compression pointers.
- *
- * return:
- *\li Number of bytes consumed in `dst' or -1 (with errno set).
- *
- * notes:
- *\li 'dnptrs' is an array of pointers to previous compressed names.
- *\li dnptrs[0] is a pointer to the beginning of the message.
- *\li The list ends with NULL. 'lastdnptr' is a pointer to the end of the
- * array pointed to by 'dnptrs'. Side effect is to update the list of
- * pointers for labels inserted into the message as we compress the name.
- *\li If 'dnptr' is NULL, we don't try to compress names. If 'lastdnptr'
- * is NULL, we don't update the list.
- */
-int
-ns_name_compress(const char *src, u_char *dst, size_t dstsiz,
- const u_char **dnptrs, const u_char **lastdnptr)
-{
- u_char tmp[NS_MAXCDNAME];
-
- if (ns_name_pton(src, tmp, sizeof tmp) == -1)
- return (-1);
- return (ns_name_pack(tmp, dst, dstsiz, dnptrs, lastdnptr));
-}
-libresolv_hidden_def (ns_name_compress)
-
-/*%
* Reset dnptrs so that there are no active references to pointers at or
* after src.
*/
diff --git a/resolv/ns_name_compress.c b/resolv/ns_name_compress.c
new file mode 100644
index 0000000..ade3676
--- /dev/null
+++ b/resolv/ns_name_compress.c
@@ -0,0 +1,50 @@
+/* Compress a DNS domain name in presentation format.
+ * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (c) 1996,1999 by Internet Software Consortium.
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
+ * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <arpa/nameser.h>
+#include <shlib-compat.h>
+
+/* Compresses a domain name into wire format, using compression pointers.
+ Returns the number of bytes consumed in DST or -1 (with errno set).
+
+ DNPTRS is an array of pointers to previous compressed names.
+ DNPTRS[0] is a pointer to the beginning of the message.
+
+ The list ends with NULL. LASTDNPTR is a pointer to the end of the
+ array pointed to by DNPTRS. Side effect is to update the list of
+ pointers for labels inserted into the message as we compress the
+ name. If DNPTRS is NULL, we don't try to compress names. If
+ LASTDNPTR * is NULL, we don't update the list. */
+int
+___ns_name_compress (const char *src, unsigned char *dst, size_t dstsiz,
+ const unsigned char **dnptrs,
+ const unsigned char **lastdnptr)
+{
+ unsigned char tmp[NS_MAXCDNAME];
+
+ if (__ns_name_pton (src, tmp, sizeof tmp) < 0)
+ return -1;
+ return __ns_name_pack (tmp, dst, dstsiz, dnptrs, lastdnptr);
+}
+versioned_symbol (libc, ___ns_name_compress, ns_name_compress, GLIBC_2_34);
+versioned_symbol (libc, ___ns_name_compress, __ns_name_compress,
+ GLIBC_PRIVATE);
+libc_hidden_ver (___ns_name_compress, __ns_name_compress)
+
+#if OTHER_SHLIB_COMPAT (libresolv, GLIBC_2_9, GLIBC_2_34)
+compat_symbol (libresolv, ___ns_name_compress, ns_name_compress, GLIBC_2_9);
+#endif