|
@@ -18,9 +18,11 @@
|
|
|
#include <asm/machdep.h>
|
|
|
#include <asm/natfeat.h>
|
|
|
|
|
|
+extern long nf_get_id2(const char *feature_name);
|
|
|
+
|
|
|
asm("\n"
|
|
|
-" .global nf_get_id,nf_call\n"
|
|
|
-"nf_get_id:\n"
|
|
|
+" .global nf_get_id2,nf_call\n"
|
|
|
+"nf_get_id2:\n"
|
|
|
" .short 0x7300\n"
|
|
|
" rts\n"
|
|
|
"nf_call:\n"
|
|
@@ -29,12 +31,25 @@ asm("\n"
|
|
|
"1: moveq.l #0,%d0\n"
|
|
|
" rts\n"
|
|
|
" .section __ex_table,\"a\"\n"
|
|
|
-" .long nf_get_id,1b\n"
|
|
|
+" .long nf_get_id2,1b\n"
|
|
|
" .long nf_call,1b\n"
|
|
|
" .previous");
|
|
|
-EXPORT_SYMBOL_GPL(nf_get_id);
|
|
|
EXPORT_SYMBOL_GPL(nf_call);
|
|
|
|
|
|
+long nf_get_id(const char *feature_name)
|
|
|
+{
|
|
|
+ /* feature_name may be in vmalloc()ed memory, so make a copy */
|
|
|
+ char name_copy[32];
|
|
|
+ size_t n;
|
|
|
+
|
|
|
+ n = strlcpy(name_copy, feature_name, sizeof(name_copy));
|
|
|
+ if (n >= sizeof(name_copy))
|
|
|
+ return 0;
|
|
|
+
|
|
|
+ return nf_get_id2(name_copy);
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(nf_get_id);
|
|
|
+
|
|
|
void nfprint(const char *fmt, ...)
|
|
|
{
|
|
|
static char buf[256];
|