socsvn commit: r272788 - soc2014/dpl/netmap-ipfwjit/sys/netpfil/ipfw
dpl at FreeBSD.org
dpl at FreeBSD.org
Thu Aug 21 18:56:40 UTC 2014
Author: dpl
Date: Thu Aug 21 18:56:39 2014
New Revision: 272788
URL: http://svnweb.FreeBSD.org/socsvn/?view=rev&rev=272788
Log:
Added stuff to bitcode
Modified:
soc2014/dpl/netmap-ipfwjit/sys/netpfil/ipfw/ip_fw_rules.c
Modified: soc2014/dpl/netmap-ipfwjit/sys/netpfil/ipfw/ip_fw_rules.c
==============================================================================
--- soc2014/dpl/netmap-ipfwjit/sys/netpfil/ipfw/ip_fw_rules.c Thu Aug 21 18:55:42 2014 (r272787)
+++ soc2014/dpl/netmap-ipfwjit/sys/netpfil/ipfw/ip_fw_rules.c Thu Aug 21 18:56:39 2014 (r272788)
@@ -1,7 +1,70 @@
-/*
- * This is the file that gets compiled when
- * generating bitcode.
- */
+ #include <sys/param.h>
+ #include <sys/ucred.h>
#define IPFW_RULES_INLINE __unused
#include "ip_fw_rules.h"
+
+// The real function will be compiled and inserted by the JIT.
+int ipfw_chk_jit(struct ip_fw_args *args, struct ip_fw_chain *chain);
+
+// Declarations of some needed structs.
+struct mbuf;
+struct ifnet;
+struct in_addr;
+struct ip;
+struct ip_fw_args;
+struct ip_fw_chain;
+struct ip_fw;
+struct _ipfw_insn;
+struct _ipfw_insn_if;
+struct _ipfw_dyn_rule;
+
+// We should hide this.
+#ifndef __FreeBSD__
+ struct bsd_ucred;
+#else
+ struct ucred;
+#endif
+
+// Functions used by JIT, external.
+int printf(const char * restrict format, ...);
+int ipfw_find_rule(struct ip_fw_chain *chain, uint32_t key, uint32_t id);
+void crfree(struct ucred *);
+
+
+// This functions only forces the compiler to store the stubs of the functions
+// so that they can be used by the JIT-compiled code instead.
+// this functions is not to be called anywhere.
+void
+voidfunction()
+{
+ struct ip_fw_args arguments;
+ struct ip_fw_chain chainss;
+
+ #ifndef __FreeBSD__
+ struct bsd_ucred user_creds;
+ #else
+ struct ucred user_creds;
+ #endif
+
+ // These two structs are not included.
+ // We need to do something with them.
+ struct _ipfw_insn_if insnif;
+ struct _ipfw_dyn_rule rules;
+
+ struct ip_fw_args *args = &arguments;
+ struct ip_fw_chain *chain = &chainss;
+
+ ipfw_find_rule(chain, 0, 0);
+ ipfw_chk_jit(args, chain);
+
+ insnif.o.opcode = 0;
+ rules.next = &rules;
+
+#ifdef __FreeBSD__
+ struct ucred *ucreds = &user_creds;
+
+ crfree(ucreds);
+#endif
+}
+
More information about the svn-soc-all
mailing list