1 # Modify as you see fit, note this is built into crda,
2 # so if you change it here you will have to change crda.c
3 REG_BIN?=/usr/lib/crda/regulatory.bin
4 REG_GIT?=git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-regdb.git
7 MANDIR ?= $(PREFIX)/share/man/
11 # Use a custom CRDA_UDEV_LEVEL when callling make install to
12 # change your desired level for the udev regulatory.rules
14 UDEV_LEVEL=$(CRDA_UDEV_LEVEL)-
15 # You can customize this if your distributions uses
16 # a different location.
17 UDEV_RULE_DIR?=/usr/lib/udev/rules.d/
19 # If your distribution requires a custom pubkeys dir
20 # you must update this variable to reflect where the
21 # keys are put when building. For example you can run
22 # with make PUBKEY_DIR=/usr/lib/crda/pubkeys
24 RUNTIME_PUBKEY_DIR?=/etc/wireless-regdb/pubkeys
32 all: all_noverify verify
34 all_noverify: crda intersect regdbdump
36 ifeq ($(USE_OPENSSL),1)
37 CFLAGS += -DUSE_OPENSSL -DPUBKEY_DIR=\"$(RUNTIME_PUBKEY_DIR)\" `pkg-config --cflags openssl`
38 LDLIBS += `pkg-config --libs openssl`
43 CFLAGS += -DUSE_GCRYPT
46 reglib.o: keys-gcrypt.c
52 NL1FOUND := $(shell pkg-config --atleast-version=1 libnl-1 && echo Y)
53 NL2FOUND := $(shell pkg-config --atleast-version=2 libnl-2.0 && echo Y)
54 NL3FOUND := $(shell pkg-config --atleast-version=3 libnl-3.0 && echo Y)
55 NL32FOUND := $(shell pkg-config --atleast-version=3 libnl-3.2 && echo Y)
58 CFLAGS += -DCONFIG_LIBNL30
59 NLLIBS += $(shell pkg-config --libs libnl-genl-3.2)
63 CFLAGS += -DCONFIG_LIBNL30
64 NLLIBS += $(shell pkg-config --libs libnl-genl-3.0)
68 CFLAGS += -DCONFIG_LIBNL20
80 $(error Cannot find development files for any supported version of libnl)
83 NLLIBS += `pkg-config --libs $(NLLIBNAME)`
84 CFLAGS += `pkg-config --cflags $(NLLIBNAME)`
95 $(NQ) ' EXIST ' $(REG_BIN)
97 $(NQ) ERROR: The file: $(REG_BIN) is missing. You need this in place in order
98 $(NQ) to verify CRDA. You can get it from:
102 $(NQ) "Once cloned (no need to build) cp regulatory.bin to $(REG_BIN)"
103 $(NQ) "Use \"make noverify\" to disable verification"
107 keys-%.c: utils/key2pub.py $(wildcard $(PUBKEY_DIR)/*.pem)
109 $(NQ) ' Trusted pubkeys:' $(wildcard $(PUBKEY_DIR)/*.pem)
110 $(Q)./utils/key2pub.py --$* $(wildcard $(PUBKEY_DIR)/*.pem) $@
112 %.o: %.c regdb.h reglib.h
114 $(Q)$(CC) -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
116 crda: reglib.o crda.o
118 $(Q)$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS) $(NLLIBS)
120 regdbdump: reglib.o regdbdump.o print-regdom.o
122 $(Q)$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS)
124 intersect: reglib.o intersect.o print-regdom.o
126 $(Q)$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS)
128 verify: $(REG_BIN) regdbdump
129 $(NQ) ' CHK $(REG_BIN)'
130 $(Q)./regdbdump $(REG_BIN) >/dev/null
136 install: crda crda.8.gz regdbdump.8.gz
137 $(NQ) ' INSTALL crda'
138 $(Q)$(MKDIR) $(DESTDIR)/$(SBINDIR)
139 $(Q)$(INSTALL) -m 755 -t $(DESTDIR)/$(SBINDIR) crda
140 $(NQ) ' INSTALL regdbdump'
141 $(Q)$(INSTALL) -m 755 -t $(DESTDIR)/$(SBINDIR) regdbdump
142 $(NQ) ' INSTALL $(UDEV_LEVEL)regulatory.rules'
143 $(Q)$(MKDIR) $(DESTDIR)/$(UDEV_RULE_DIR)/
144 @# This removes the old rule you may have, we were not
145 @# putting it in the right place.
146 $(Q)rm -f $(DESTDIR)/etc/udev/rules.d/regulatory.rules
147 $(Q)sed 's:$$(SBINDIR):$(SBINDIR):' udev/regulatory.rules > udev/regulatory.rules.parsed
148 $(Q)ln -sf regulatory.rules.parsed udev/$(UDEV_LEVEL)regulatory.rules
149 $(Q)$(INSTALL) -m 644 -t \
150 $(DESTDIR)/$(UDEV_RULE_DIR)/ \
151 udev/$(UDEV_LEVEL)regulatory.rules
152 $(NQ) ' INSTALL crda.8.gz'
153 $(Q)$(MKDIR) $(DESTDIR)$(MANDIR)/man8/
154 $(Q)$(INSTALL) -m 644 -t $(DESTDIR)/$(MANDIR)/man8/ crda.8.gz
155 $(NQ) ' INSTALL regdbdump.8.gz'
156 $(Q)$(INSTALL) -m 644 -t $(DESTDIR)/$(MANDIR)/man8/ regdbdump.8.gz
159 $(Q)rm -f crda regdbdump intersect *.o *~ *.pyc keys-*.c *.gz \
160 udev/$(UDEV_LEVEL)regulatory.rules udev/regulatory.rules.parsed