|
|
c55e18 |
diff -up Linux-PAM-1.3.1/libpam/include/pam_cc_compat.h.inline Linux-PAM-1.3.1/libpam/include/pam_cc_compat.h
|
|
|
c55e18 |
--- Linux-PAM-1.3.1/libpam/include/pam_cc_compat.h.inline 2022-05-26 10:44:31.702623614 +0200
|
|
|
c55e18 |
+++ Linux-PAM-1.3.1/libpam/include/pam_cc_compat.h 2022-05-26 10:44:31.703623621 +0200
|
|
|
c55e18 |
@@ -44,4 +44,17 @@
|
|
|
c55e18 |
# define DIAG_POP_IGNORE_CAST_ALIGN /* empty */
|
|
|
c55e18 |
#endif
|
|
|
c55e18 |
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Evaluates to
|
|
|
c55e18 |
+ * 1, if the given two types are known to be the same
|
|
|
c55e18 |
+ * 0, otherwise.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+#if PAM_GNUC_PREREQ(3, 0)
|
|
|
c55e18 |
+# define PAM_IS_SAME_TYPE(x_, y_) \
|
|
|
c55e18 |
+ __builtin_types_compatible_p(__typeof__(x_), __typeof__(y_))
|
|
|
c55e18 |
+#else
|
|
|
c55e18 |
+/* Cannot tell whether these types are the same. */
|
|
|
c55e18 |
+# define PAM_IS_SAME_TYPE(x_, y_) 0
|
|
|
c55e18 |
+#endif
|
|
|
c55e18 |
+
|
|
|
c55e18 |
#endif /* PAM_CC_COMPAT_H */
|
|
|
c55e18 |
diff -up Linux-PAM-1.3.1/libpam/include/pam_inline.h.inline Linux-PAM-1.3.1/libpam/include/pam_inline.h
|
|
|
c55e18 |
--- Linux-PAM-1.3.1/libpam/include/pam_inline.h.inline 2022-05-26 10:44:31.703623621 +0200
|
|
|
c55e18 |
+++ Linux-PAM-1.3.1/libpam/include/pam_inline.h 2022-05-26 10:44:31.703623621 +0200
|
|
|
c55e18 |
@@ -0,0 +1,67 @@
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Copyright (c) 2020 Dmitry V. Levin <ldv@altlinux.org>
|
|
|
c55e18 |
+ *
|
|
|
c55e18 |
+ * Handy inline functions and macros providing some convenient functionality
|
|
|
c55e18 |
+ * to libpam and its modules.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+#ifndef PAM_INLINE_H
|
|
|
c55e18 |
+#define PAM_INLINE_H
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+#include "pam_cc_compat.h"
|
|
|
c55e18 |
+#include <string.h>
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Evaluates to
|
|
|
c55e18 |
+ * - a syntax error if the argument is 0,
|
|
|
c55e18 |
+ * 0, otherwise.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+#define PAM_FAIL_BUILD_ON_ZERO(e_) (sizeof(int[-1 + 2 * !!(e_)]) * 0)
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Evaluates to
|
|
|
c55e18 |
+ * 1, if the given type is known to be a non-array type
|
|
|
c55e18 |
+ * 0, otherwise.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+#define PAM_IS_NOT_ARRAY(a_) PAM_IS_SAME_TYPE((a_), &(a_)[0])
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Evaluates to
|
|
|
c55e18 |
+ * - a syntax error if the argument is not an array,
|
|
|
c55e18 |
+ * 0, otherwise.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+#define PAM_MUST_BE_ARRAY(a_) PAM_FAIL_BUILD_ON_ZERO(!PAM_IS_NOT_ARRAY(a_))
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/* Evaluates to the number of elements in the specified array. */
|
|
|
c55e18 |
+#define PAM_ARRAY_SIZE(a_) (sizeof(a_) / sizeof((a_)[0]) + PAM_MUST_BE_ARRAY(a_))
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Returns NULL if STR does not start with PREFIX,
|
|
|
c55e18 |
+ * or a pointer to the first char in STR after PREFIX.
|
|
|
c55e18 |
+ * The length of PREFIX is specified by PREFIX_LEN.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+static inline const char *
|
|
|
c55e18 |
+pam_str_skip_prefix_len(const char *str, const char *prefix, size_t prefix_len)
|
|
|
c55e18 |
+{
|
|
|
c55e18 |
+ return strncmp(str, prefix, prefix_len) ? NULL : str + prefix_len;
|
|
|
c55e18 |
+}
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+#define pam_str_skip_prefix(str_, prefix_) \
|
|
|
c55e18 |
+ pam_str_skip_prefix_len((str_), (prefix_), sizeof(prefix_) - 1 + PAM_MUST_BE_ARRAY(prefix_))
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+/*
|
|
|
c55e18 |
+ * Returns NULL if STR does not start with PREFIX
|
|
|
c55e18 |
+ * (ignoring the case of the characters),
|
|
|
c55e18 |
+ * or a pointer to the first char in STR after PREFIX.
|
|
|
c55e18 |
+ * The length of PREFIX is specified by PREFIX_LEN.
|
|
|
c55e18 |
+ */
|
|
|
c55e18 |
+static inline const char *
|
|
|
c55e18 |
+pam_str_skip_icase_prefix_len(const char *str, const char *prefix, size_t prefix_len)
|
|
|
c55e18 |
+{
|
|
|
c55e18 |
+ return strncasecmp(str, prefix, prefix_len) ? NULL : str + prefix_len;
|
|
|
c55e18 |
+}
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+#define pam_str_skip_icase_prefix(str_, prefix_) \
|
|
|
c55e18 |
+ pam_str_skip_icase_prefix_len((str_), (prefix_), sizeof(prefix_) - 1 + PAM_MUST_BE_ARRAY(prefix_))
|
|
|
c55e18 |
+
|
|
|
c55e18 |
+#endif /* PAM_INLINE_H */
|
|
|
c55e18 |
diff -up Linux-PAM-1.3.1/libpam/Makefile.am.inline Linux-PAM-1.3.1/libpam/Makefile.am
|
|
|
c55e18 |
--- Linux-PAM-1.3.1/libpam/Makefile.am.inline 2022-05-26 10:44:31.702623614 +0200
|
|
|
c55e18 |
+++ Linux-PAM-1.3.1/libpam/Makefile.am 2022-05-26 10:45:21.146977780 +0200
|
|
|
c55e18 |
@@ -18,7 +18,8 @@ include_HEADERS = include/security/_pam_
|
|
|
c55e18 |
include/security/pam_ext.h include/security/pam_modutil.h
|
|
|
c55e18 |
|
|
|
c55e18 |
noinst_HEADERS = pam_prelude.h pam_private.h pam_tokens.h \
|
|
|
c55e18 |
- pam_modutil_private.h include/pam_cc_compat.h
|
|
|
c55e18 |
+ pam_modutil_private.h include/pam_cc_compat.h \
|
|
|
c55e18 |
+ include/pam_inline.h
|
|
|
c55e18 |
|
|
|
c55e18 |
libpam_la_LDFLAGS = -no-undefined -version-info 84:2:84
|
|
|
c55e18 |
libpam_la_LIBADD = @LIBAUDIT@ $(LIBPRELUDE_LIBS) @LIBDL@
|