Date: Thu, 15 Feb 2007 20:28:11 GMT From: Todd Miller <millert@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 114584 for review Message-ID: <200702152028.l1FKSBgm073734@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=114584 Change 114584 by millert@millert_p4 on 2007/02/15 20:27:17 Make avc audit rouines use uma_zalloc() and keep a spare buffer around for efficiency. Also add some more types to linux-compat.h and remove the non-kernel pieces. Affected files ... .. //depot/projects/trustedbsd/sebsd/sys/security/sebsd/avc/avc_audit.c#2 edit .. //depot/projects/trustedbsd/sebsd/sys/security/sebsd/linux-compat.h#5 edit Differences ... ==== //depot/projects/trustedbsd/sebsd/sys/security/sebsd/avc/avc_audit.c#2 (text+ko) ==== @@ -33,11 +33,13 @@ #include <sys/lock.h> #include <sys/mutex.h> #include <sys/systm.h> +#include <vm/uma.h> #include <machine/stdarg.h> #include <security/sebsd/linux-compat.h> #include <security/sebsd/sebsd.h> +#include <security/sebsd/avc/avc.h> /* * Emulate Linux audit API. @@ -45,7 +47,7 @@ * TBD: use a freelist so we don't have to mallc/free so much. */ -static struct mtx avc_log_lock; +struct mtx avc_log_lock; MTX_SYSINIT(avc_log_lock, &avc_log_lock, "SEBSD message lock", MTX_DEF); struct audit_buffer { @@ -53,15 +55,34 @@ char buf[1024]; }; +static uma_zone_t avc_audit_zone; /* audit buffer zone */ +static struct audit_buffer *spare_buf; /* spare buffer */ + +void +avc_audit_init(void) +{ + + avc_audit_zone = uma_zcreate("avc_audit", sizeof(struct audit_buffer), + NULL, NULL, NULL, NULL, UMA_ALIGN_PTR, 0); + spare_buf = uma_zalloc(avc_audit_zone, M_WAITOK); +} + struct audit_buffer * -audit_log_start(void) +_audit_log_start(int flag) { - struct audit_buffer *ab; + struct audit_buffer *ab = spare_buf; - ab = sebsd_malloc(sizeof(*ab), M_SEBSD, M_NOWAIT); + /* Use a free buffer if available, else alloc a new one. */ + if (ab != NULL && + atomic_cmpset_ptr((intptr_t *)&spare_buf, (intptr_t)ab, 0) == 0) + ab = NULL; if (ab == NULL) { - printf("%s: unable to allocate audit buffer\n", __func__); - return (NULL); + ab = uma_zalloc(avc_audit_zone, flag); + if (ab == NULL) { + printf("%s: unable to allocate audit buffer\n", + __func__); + return (NULL); + } } sbuf_new(&ab->sbuf, ab->buf, sizeof(ab->buf), SBUF_FIXEDLEN); return (ab); @@ -75,24 +96,13 @@ mtx_lock(&avc_log_lock); printf("\n%s\n", sbuf_data(&ab->sbuf)); mtx_unlock(&avc_log_lock); - sbuf_delete(&ab->sbuf); - sebsd_free(ab, M_SEBSD); + /* Always keep a free buffer around. */ + if (spare_buf != NULL || + atomic_cmpset_ptr((intptr_t *)&spare_buf, 0, (intptr_t)ab) == 0) + uma_zfree(avc_audit_zone, ab); } void -audit_log(const char *fmt, ...) -{ - va_list ap; - - va_start(ap, fmt); - mtx_lock(&avc_log_lock); - vprintf(fmt, ap); - printf("\n"); - mtx_unlock(&avc_log_lock); - va_end(ap); -} - -void audit_log_format(struct audit_buffer *ab, const char *fmt, ...) { va_list ap; @@ -106,5 +116,5 @@ audit_log_untrustedstring(struct audit_buffer *ab, const char *s) { - sbuf_cat(&ab->sbuf, s); + sbuf_cat(&ab->sbuf, s); /* XXX - wants vis(3) support */ } ==== //depot/projects/trustedbsd/sebsd/sys/security/sebsd/linux-compat.h#5 (text+ko) ==== @@ -48,51 +48,31 @@ #include <sys/types.h> #include <sys/endian.h> +#include <sys/libkern.h> typedef u_int64_t u64; typedef u_int64_t __le64; typedef u_int32_t u32; typedef u_int32_t __le32; +typedef u_int32_t __be32; typedef u_int16_t u16; typedef u_int16_t __le16; typedef u_int16_t __be16; typedef u_int8_t u8; +typedef int gfp_t; -#ifndef _KERNEL - -#if BYTE_ORDER == LITTLE_ENDIAN -#define cpu_to_le16(x) ((__uint16_t)(x)) -#define cpu_to_le32(x) ((__uint32_t)(x)) -#define cpu_to_le64(x) ((__uint64_t)(x)) -#define le16_to_cpu(x) ((__uint16_t)(x)) -#define le32_to_cpu(x) ((__uint32_t)(x)) -#define le64_to_cpu(x) ((__uint64_t)(x)) -#else /* BYTE_ORDER != LITTLE_ENDIAN */ -#define cpu_to_le16(x) bswap16((x)) -#define cpu_to_le32(x) bswap32((x)) -#define cpu_to_le64(x) bswap64((x)) -#define le16_to_cpu(x) bswap16((x)) -#define le32_to_cpu(x) bswap32((x)) -#define le64_to_cpu(x) bswap64((x)) -#endif /* BYTE_ORDER */ - -/* sebsd uses same ss source files for userspace */ - -#define kcalloc(nmemb, size, flags) calloc(nmemb, size) -#define kmalloc(size,flags) malloc(size) -#define kzalloc(size,flags) calloc(1, size) -#define kfree(v) free(v) -#define __get_free_page(flags) malloc (4096) /* XXX need page size */ -#define GFP_ATOMIC 1 -#define GFP_KERNEL 2 - -#else /* _KERNEL */ - +#define cpu_to_le16(a) htole16(a) +#define cpu_to_le32(a) htole32(a) +#define cpu_to_le64(a) htole64(a) #define le16_to_cpu(a) le16toh(a) #define le32_to_cpu(a) le32toh(a) #define le64_to_cpu(a) le64toh(a) +/* branch prediction macros, uses a GCC extension. */ +#define likely(exp) __builtin_expect(!!(exp), 1) +#define unlikely(exp) __builtin_expect(!!(exp), 0) + #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) #define NIPQUAD(addr) \ @@ -104,13 +84,13 @@ #define __init /* kmalloc */ -#define kcalloc(nmemb, size, flags) sebsd_malloc(nmemb * size, M_SEBSD, flags | M_ZERO) -#define kmalloc(size,flags) malloc(size, M_SEBSD, flags) -#define kzalloc(size,flags) malloc(size, M_SEBSD, flags | M_ZERO) -#define kfree(v) free(v, M_SEBSD) -#define __get_free_page(flags) malloc(4096, M_SEBSD, flags) /* XXX need page size */ #define GFP_ATOMIC M_NOWAIT #define GFP_KERNEL M_NOWAIT +#define kcalloc(nmemb, size, flags) malloc(nmemb * size, M_SEBSD, flags | M_ZERO) +#define kmalloc(size,flags) malloc(size, M_SEBSD, flags) +#define kzalloc(size,flags) malloc(size, M_SEBSD, flags | M_ZERO) +#define kfree(v) free(v, M_SEBSD) +#define __get_free_page(flags) malloc(4096, M_SEBSD, flags) /* XXX need page size */ /* also defined in sebsd.h */ #ifndef sebsd_malloc @@ -124,22 +104,46 @@ #define _M_SEBSD_DEF #endif -/* spinlock */ +static inline char * +kstrdup(const char *str, int mflag) +{ + char *newstr; + size_t len = strlen(str) + 1; + + newstr = malloc(len, M_SEBSD, mflag); + if (newstr != NULL) + memcpy(newstr, str, len); + return (newstr); +} + +/* FreeBSD has no spinlock, use mutex instead */ #define spinlock_t struct mtx #define spin_lock_irqsave(m,flags) mtx_lock(m) #define spin_unlock_irqrestore(m,flags) mtx_unlock(m) /* emulate linux audit support */ +extern struct mtx avc_log_lock; struct audit_buffer; -struct audit_buffer *audit_log_start(void); -void audit_log(const char *, ...); +struct audit_buffer *_audit_log_start(int); void audit_log_end(struct audit_buffer *); void audit_log_format(struct audit_buffer *, const char *, ...); void audit_log_untrustedstring(struct audit_buffer *, const char *); +#define audit_log_start(ac, mf, af) _audit_log_start(mf) +#define audit_log(ac, mf, af, ...) do { \ + mtx_lock(&avc_log_lock); \ + printf(__VA_ARGS__); \ + printf("\n"); \ + mtx_unlock(&avc_log_lock); \ +} while (0) +#define sebsd_log(fmt, ...) printf(fmt "\n", __VA_ARGS__) + +/* we don't enable the selinux netlbl support */ +#define selinux_netlbl_cache_invalidate() /* * Atomic integer operations, Linux style */ +typedef unsigned int atomic_t; #define atomic_inc(p) atomic_add_acq_32(p, 1) #define atomic_inc_return(p) atomic_fetchadd_32(p, 1) #define atomic_dec(p) atomic_subtract_acq_32(p, 1) @@ -150,8 +154,6 @@ /* FreeBSD has index() not strchr() in the kernel. */ #define strchr(s, c) index(s, c) -#endif /* _KERNEL */ - #define BUG() printf("BUG: %s:%d", __FILE__, __LINE__) #define BUG_ON(x) do { if (x) BUG(); } while(0)
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200702152028.l1FKSBgm073734>