]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
MEDIUM: protocol: use a family array to index the protocol handlers
authorWilly Tarreau <willy@haproxy.com>
Fri, 20 Feb 2015 15:53:25 +0000 (16:53 +0100)
committerWilly Tarreau <w@1wt.eu>
Sat, 28 Feb 2015 22:12:31 +0000 (23:12 +0100)
Instead of walking over a list, we now have a direct mapping between
protocol families and their respective handlers. This will allow fast
lookups.

include/proto/protocol.h
src/protocol.c

index 1842faf167bb5145d035ad4d40479c735f6b5422..13a3c0a61bf3880bdf4e13bbcae739985495252c 100644 (file)
 #ifndef _PROTO_PROTOCOL_H
 #define _PROTO_PROTOCOL_H
 
+#include <sys/socket.h>
 #include <types/protocol.h>
 
+extern struct protocol *__protocol_by_family[AF_MAX];
+
 /* Registers the protocol <proto> */
 void protocol_register(struct protocol *proto);
 
@@ -51,7 +54,12 @@ int protocol_unbind_all(void);
 int protocol_enable_all(void);
 
 /* returns the protocol associated to family <family> or NULL if not found */
-struct protocol *protocol_by_family(int family);
+static inline struct protocol *protocol_by_family(int family)
+{
+       if (family >= 0 && family < AF_MAX)
+               return __protocol_by_family[family];
+       return NULL;
+}
 
 #endif /* _PROTO_PROTOCOL_H */
 
index 84d23dab089a4313913e22c1b0c60cc2b48216f0..3caccb6a3f7ff6f933becd7140a3e53f296f20f6 100644 (file)
@@ -10,6 +10,8 @@
  *
  */
 
+#include <sys/socket.h>
+
 #include <common/config.h>
 #include <common/errors.h>
 #include <common/mini-clist.h>
 
 /* List head of all registered protocols */
 static struct list protocols = LIST_HEAD_INIT(protocols);
+struct protocol *__protocol_by_family[AF_MAX] = { };
 
 /* Registers the protocol <proto> */
 void protocol_register(struct protocol *proto)
 {
        LIST_ADDQ(&protocols, &proto->list);
+       if (proto->sock_domain >= 0 && proto->sock_domain < AF_MAX)
+               __protocol_by_family[proto->sock_domain] = proto;
 }
 
 /* Unregisters the protocol <proto>. Note that all listeners must have
@@ -109,18 +114,6 @@ int protocol_disable_all(void)
        return err;
 }
 
-/* Returns the protocol handler for socket family <family> or NULL if not found */
-struct protocol *protocol_by_family(int family)
-{
-       struct protocol *proto;
-
-       list_for_each_entry(proto, &protocols, list) {
-               if (proto->sock_domain == family)
-                       return proto;
-       }
-       return NULL;
-}
-
 /*
  * Local variables:
  *  c-indent-level: 8