summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/ldapd/btree.c7
-rw-r--r--usr.sbin/ldapd/index.c4
-rw-r--r--usr.sbin/ldapd/search.c8
3 files changed, 12 insertions, 7 deletions
diff --git a/usr.sbin/ldapd/btree.c b/usr.sbin/ldapd/btree.c
index ae4c2f00fc0..8397e23910d 100644
--- a/usr.sbin/ldapd/btree.c
+++ b/usr.sbin/ldapd/btree.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: btree.c,v 1.3 2010/06/02 09:12:13 martinh Exp $ */
+/* $OpenBSD: btree.c,v 1.4 2010/06/03 17:32:25 martinh Exp $ */
/*
* Copyright (c) 2009, 2010 Martin Hedenfalk <martin@bzero.se>
@@ -173,7 +173,7 @@ struct node {
uint16_t ksize; /* key size */
#define F_BIGDATA 0x01 /* data put on overflow page */
uint8_t flags;
- char data[];
+ char data[1];
};
struct btree_txn {
@@ -2168,6 +2168,7 @@ btree_merge(struct btree *bt, struct mpage *src, struct mpage *dst)
{
int rc;
indx_t i;
+ unsigned int pfxlen;
struct node *srcnode;
struct btkey tmpkey, dstpfx;
struct btval key, data;
@@ -2240,7 +2241,7 @@ btree_merge(struct btree *bt, struct mpage *src, struct mpage *dst)
if (btree_update_key(bt, src->parent, 0, &key) != BT_SUCCESS)
return BT_FAIL;
- unsigned int pfxlen = src->prefix.len;
+ pfxlen = src->prefix.len;
find_common_prefix(bt, src);
assert (src->prefix.len == pfxlen);
}
diff --git a/usr.sbin/ldapd/index.c b/usr.sbin/ldapd/index.c
index 9db1d2feb40..11fd2f53135 100644
--- a/usr.sbin/ldapd/index.c
+++ b/usr.sbin/ldapd/index.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: index.c,v 1.2 2010/05/31 18:29:04 martinh Exp $ */
+/* $OpenBSD: index.c,v 1.3 2010/06/03 17:32:25 martinh Exp $ */
/*
* Copyright (c) 2009 Martin Hedenfalk <martin@bzero.se>
@@ -375,7 +375,7 @@ continue_indexer(int fd, short why, void *arg)
struct ber_element *elm;
struct btval key, val;
struct timeval tv;
- int i, rc;
+ int i, rc = BT_FAIL;
if (c->cursor == NULL) {
log_info("begin indexing namespace %s", c->ns->suffix);
diff --git a/usr.sbin/ldapd/search.c b/usr.sbin/ldapd/search.c
index 5ee50e010db..6d134811f89 100644
--- a/usr.sbin/ldapd/search.c
+++ b/usr.sbin/ldapd/search.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: search.c,v 1.2 2010/05/31 18:29:04 martinh Exp $ */
+/* $OpenBSD: search.c,v 1.3 2010/06/03 17:32:25 martinh Exp $ */
/*
* Copyright (c) 2009, 2010 Martin Hedenfalk <martin@bzero.se>
@@ -195,6 +195,7 @@ static int
check_search_entry(struct btval *key, struct btval *val, struct search *search)
{
int rc;
+ char *dn0;
struct ber_element *elm;
/* verify entry is a direct subordinate of basedn */
@@ -204,7 +205,10 @@ check_search_entry(struct btval *key, struct btval *val, struct search *search)
return 0;
}
- char *dn0 = malloc(key->size + 1);
+ if ((dn0 = malloc(key->size + 1)) == NULL) {
+ log_warn("malloc");
+ return 0;
+ }
strncpy(dn0, key->data, key->size);
dn0[key->size] = 0;
if (!authorized(search->conn, search->ns, ACI_READ, dn0,