summaryrefslogtreecommitdiff
path: root/usr.sbin/smtpd/queue.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/smtpd/queue.c')
-rw-r--r--usr.sbin/smtpd/queue.c35
1 files changed, 13 insertions, 22 deletions
diff --git a/usr.sbin/smtpd/queue.c b/usr.sbin/smtpd/queue.c
index dd37bcaa1f6..d2447973f28 100644
--- a/usr.sbin/smtpd/queue.c
+++ b/usr.sbin/smtpd/queue.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: queue.c,v 1.31 2008/12/18 15:11:21 jacekm Exp $ */
+/* $OpenBSD: queue.c,v 1.32 2008/12/27 17:03:29 jacekm Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -62,7 +62,6 @@ int queue_open_message_file(struct batch *);
int queue_batch_resolved(struct smtpd *, struct batch *);
int queue_message_schedule(struct message *, time_t);
void queue_delete_message_file(char *);
-u_int16_t queue_message_hash(struct message *);
int queue_record_incoming_envelope(struct message *);
int queue_update_incoming_envelope(struct message *);
int queue_remove_incoming_envelope(struct message *);
@@ -78,7 +77,6 @@ int queue_load_envelope(struct message *, char *);
void queue_delete_message(char *);
void batch_send(struct smtpd *, struct batch *, time_t);
-u_int32_t hash(u_int8_t *, size_t);
struct batch *queue_record_batch(struct smtpd *, struct message *);
struct batch *batch_by_id(struct smtpd *, u_int64_t);
struct message *message_by_id(struct smtpd *, struct batch *, u_int64_t);
@@ -930,7 +928,7 @@ queue_commit_incoming_message(struct message *messagep)
messagep->message_id))
fatal("queue_commit_message_incoming: snprintf");
- hval = queue_message_hash(messagep);
+ hval = queue_hash(messagep->message_id);
if (! bsnprintf(queuedir, MAXPATHLEN, "%s/%d", PATH_QUEUE, hval))
fatal("queue_commit_message_incoming: snprintf");
@@ -983,7 +981,7 @@ queue_record_envelope(struct message *messagep)
messagep->message_id))
fatal("queue_record_envelope: snprintf");
- hval = queue_message_hash(messagep);
+ hval = queue_hash(messagep->message_id);
if (! bsnprintf(queuedir, MAXPATHLEN, "%s/%d", PATH_QUEUE, hval))
fatal("queue_record_envelope: snprintf");
@@ -1041,7 +1039,7 @@ queue_remove_envelope(struct message *messagep)
char pathname[MAXPATHLEN];
u_int16_t hval;
- hval = queue_message_hash(messagep);
+ hval = queue_hash(messagep->message_id);
if (! bsnprintf(pathname, MAXPATHLEN, "%s/%d/%s%s/%s", PATH_QUEUE,
hval, messagep->message_id, PATH_ENVELOPES,
@@ -1070,7 +1068,7 @@ queue_update_envelope(struct message *messagep)
mode_t mode = O_RDWR;
u_int16_t hval;
- hval = queue_message_hash(messagep);
+ hval = queue_hash(messagep->message_id);
if (! bsnprintf(pathname, MAXPATHLEN, "%s/%d/%s%s/%s", PATH_QUEUE,
hval, messagep->message_id, PATH_ENVELOPES, messagep->message_uid))
@@ -1106,7 +1104,7 @@ queue_load_envelope(struct message *messagep, char *evpid)
strlcpy(msgid, evpid, MAXPATHLEN);
*strrchr(msgid, '.') = '\0';
- hval = hash(msgid, strlen(msgid)) % DIRHASH_BUCKETS;
+ hval = queue_hash(msgid);
if (! bsnprintf(pathname, MAXPATHLEN, "%s/%d/%s%s/%s", PATH_QUEUE,
hval, msgid, PATH_ENVELOPES, evpid))
return 0;
@@ -1131,7 +1129,7 @@ queue_open_message_file(struct batch *batchp)
mode_t mode = O_RDONLY;
u_int16_t hval;
- hval = hash(batchp->message_id, strlen(batchp->message_id)) % DIRHASH_BUCKETS;
+ hval = queue_hash(batchp->message_id);
if (! bsnprintf(pathname, MAXPATHLEN, "%s/%d/%s/message", PATH_QUEUE,
hval, batchp->message_id))
@@ -1151,7 +1149,7 @@ queue_delete_message(char *msgid)
char msgpath[MAXPATHLEN];
u_int16_t hval;
- hval = hash(msgid, strlen(msgid)) % DIRHASH_BUCKETS;
+ hval = queue_hash(msgid);
if (! bsnprintf(rootdir, MAXPATHLEN, "%s/%d/%s", PATH_QUEUE,
hval, msgid))
fatal("queue_delete_message: snprintf");
@@ -1185,19 +1183,12 @@ queue_delete_message(char *msgid)
}
u_int16_t
-queue_message_hash(struct message *messagep)
+queue_hash(char *msgid)
{
- return hash(messagep->message_id, strlen(messagep->message_id))
- % DIRHASH_BUCKETS;
-}
-
-u_int32_t
-hash(u_int8_t *buf, size_t len)
-{
- u_int32_t h;
+ u_int16_t h;
- for (h = 5381; len; len--)
- h = ((h << 5) + h) + *buf++;
+ for (h = 5381; *msgid; msgid++)
+ h = ((h << 5) + h) + *msgid;
- return h;
+ return (h % DIRHASH_BUCKETS);
}