1 # ------------------------------------------------------------------------------
2 # Copyright (C) 2008-2009 Kay Sievers <kay.sievers@vrfy.org>
3 # Copyright (C) 2009 Diego Elio 'Flameeyes' Pettenò <flameeyes@gmail.com>
4 # ------------------------------------------------------------------------------
8 EXTRA_DIST = autogen.sh
10 ACLOCAL_AMFLAGS = -I m4
12 AM_MAKEFLAGS = --no-print-directory
15 -include $(top_builddir)/config.h \
16 -I$(top_srcdir)/libudev \
17 -DSYSCONFDIR=\""$(sysconfdir)"\" \
18 -DLIBEXECDIR=\""$(libexecdir)"\"
23 DISTCHECK_CONFIGURE_FLAGS = \
25 --with-systemdsystemunitdir=$$dc_install_base/$(systemdsystemunitdir)
31 UNINSTALL_EXEC_HOOKS =
34 # ------------------------------------------------------------------------------
36 # ------------------------------------------------------------------------------
41 SUBDIRS += libudev/docs
43 include_HEADERS = libudev/libudev.h
44 lib_LTLIBRARIES = libudev/libudev.la
46 libudev_libudev_la_SOURCES =\
47 libudev/libudev-private.h \
49 libudev/libudev-list.c \
50 libudev/libudev-util.c \
51 libudev/libudev-device.c \
52 libudev/libudev-enumerate.c \
53 libudev/libudev-monitor.c \
54 libudev/libudev-queue.c
56 libudev_libudev_la_LDFLAGS = \
57 -version-info $(LIBUDEV_CURRENT):$(LIBUDEV_REVISION):$(LIBUDEV_AGE) \
58 -export-symbols $(top_srcdir)/libudev/exported_symbols
60 noinst_LTLIBRARIES = \
61 libudev/libudev-private.la
63 libudev_libudev_private_la_SOURCES =\
64 $(libudev_libudev_la_SOURCES) \
65 libudev/libudev-ctrl.c \
66 libudev/libudev-util-private.c \
67 libudev/libudev-device-private.c \
68 libudev/libudev-queue-private.c
71 libudev_libudev_private_la_SOURCES += libudev/libudev-selinux-private.c
72 libudev_libudev_private_la_LIBADD = $(SELINUX_LIBS)
75 pkgconfigdir = $(libdir)/pkgconfig
76 pkgconfig_DATA = libudev/libudev.pc
78 EXTRA_DIST += libudev/exported_symbols libudev/COPYING
79 # move lib from $(libdir) to $(rootlib_execdir) and update devel link, if needed
80 libudev-install-move-hook:
81 if test "$(libdir)" != "$(rootlib_execdir)"; then \
82 mkdir -p $(DESTDIR)$(rootlib_execdir) && \
83 so_img_name=$$(readlink $(DESTDIR)$(libdir)/libudev.so) && \
84 so_img_rel_target_prefix=$$(echo $(libdir) | sed 's,\(^/\|\)[^/][^/]*,..,g') && \
85 ln -sf $$so_img_rel_target_prefix$(rootlib_execdir)/$$so_img_name $(DESTDIR)$(libdir)/libudev.so && \
86 mv $(DESTDIR)$(libdir)/libudev.so.* $(DESTDIR)$(rootlib_execdir); \
89 libudev-uninstall-move-hook:
90 rm -f $(DESTDIR)$(rootlib_execdir)/libudev.so*
92 INSTALL_EXEC_HOOKS += libudev-install-move-hook
93 UNINSTALL_EXEC_HOOKS += libudev-uninstall-move-hook
95 # ------------------------------------------------------------------------------
97 # ------------------------------------------------------------------------------
99 -mkdir -p $(DESTDIR)$(sysconfdir)/udev/rules.d
100 -mkdir -p $(DESTDIR)$(libexecdir)/devices
102 INSTALL_DATA_HOOKS += udev-confdirs
108 udevrulesdir = $(libexecdir)/rules.d
109 dist_udevrules_DATA = \
110 rules/rules.d/50-udev-default.rules \
111 rules/rules.d/60-persistent-storage.rules \
112 rules/rules.d/60-persistent-storage-tape.rules \
113 rules/rules.d/60-persistent-serial.rules \
114 rules/rules.d/60-persistent-input.rules \
115 rules/rules.d/60-persistent-alsa.rules \
116 rules/rules.d/80-drivers.rules \
117 rules/rules.d/95-udev-late.rules
119 udevconfdir = $(sysconfdir)/udev
120 dist_udevconf_DATA = udev.conf
122 sharepkgconfigdir = $(datadir)/pkgconfig
123 sharepkgconfig_DATA = udev/udev.pc
126 systemdsystemunit_DATA = \
129 init/udev-trigger.service \
130 init/udev-settle.service
132 EXTRA_DIST += init/udev.socket
134 systemd-install-hook:
135 mkdir -p $(DESTDIR)$(systemdsystemunitdir)/sockets.target.wants
136 ln -sf ../udev.socket $(DESTDIR)$(systemdsystemunitdir)/sockets.target.wants/udev.socket
137 mkdir -p $(DESTDIR)$(systemdsystemunitdir)/basic.target.wants
138 ln -sf ../udev.service $(DESTDIR)$(systemdsystemunitdir)/basic.target.wants/udev.service
139 ln -sf ../udev-trigger.service $(DESTDIR)$(systemdsystemunitdir)/basic.target.wants/udev-trigger.service
141 INSTALL_DATA_HOOKS += systemd-install-hook
148 udev_common_sources =\
155 udev_udevd_SOURCES = \
156 $(udev_common_sources) \
160 udev_udevd_LDADD = libudev/libudev-private.la
162 udev_udevadm_SOURCES = \
163 $(udev_common_sources) \
165 udev/udevadm-info.c \
166 udev/udevadm-control.c \
167 udev/udevadm-test.c \
168 udev/udevadm-monitor.c \
169 udev/udevadm-settle.c \
170 udev/udevadm-trigger.c
171 udev_udevadm_LDADD = libudev/libudev-private.la
173 # ------------------------------------------------------------------------------
175 # ------------------------------------------------------------------------------
191 udev/%.7 udev/%.8 : udev/%.xml
192 $(AM_V_GEN)$(XSLTPROC) -o $@ -nonet http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl $<
194 udev/%.html : udev/%.xml
195 $(AM_V_GEN)$(XSLTPROC) -o $@ -nonet http://docbook.sourceforge.net/release/xsl/current/xhtml-1_1/docbook.xsl $<
197 # ------------------------------------------------------------------------------
199 # ------------------------------------------------------------------------------
200 TESTS = test/udev-test.pl test/rules-test.sh
203 libudev/test-libudev \
206 libudev_test_libudev_SOURCES = libudev/test-libudev.c
207 libudev_test_libudev_LDADD = libudev/libudev.la
209 udev_test_udev_SOURCES = \
210 $(udev_common_sources) \
212 udev_test_udev_LDADD = libudev/libudev-private.la
214 # ------------------------------------------------------------------------------
215 # rule_generator - persistent network and optical device rule generator
216 # ------------------------------------------------------------------------------
217 dist_libexec_SCRIPTS = \
218 extras/rule_generator/write_cd_rules \
219 extras/rule_generator/write_net_rules
221 udevhomedir = $(libexecdir)
222 dist_udevhome_DATA = extras/rule_generator/rule_generator.functions
224 dist_udevrules_DATA += \
225 extras/rule_generator/75-cd-aliases-generator.rules \
226 extras/rule_generator/75-persistent-net-generator.rules
228 # ------------------------------------------------------------------------------
229 # firmware - firmware loading
230 # ------------------------------------------------------------------------------
231 extras_firmware_firmware_SOURCES = extras/firmware/firmware.c
232 extras_firmware_firmware_LDADD = libudev/libudev-private.la
233 extras_firmware_firmware_CPPFLAGS = $(AM_CPPFLAGS) -DFIRMWARE_PATH="$(FIRMWARE_PATH)"
234 dist_udevrules_DATA += extras/firmware/50-firmware.rules
235 libexec_PROGRAMS = extras/firmware/firmware
237 # ------------------------------------------------------------------------------
238 # ata_id - ATA identify
239 # ------------------------------------------------------------------------------
240 extras_ata_id_ata_id_SOURCES = extras/ata_id/ata_id.c
241 extras_ata_id_ata_id_LDADD = libudev/libudev-private.la
242 libexec_PROGRAMS += extras/ata_id/ata_id
244 # ------------------------------------------------------------------------------
245 # cdrom_id - optical drive/media capability
246 # ------------------------------------------------------------------------------
247 extras_cdrom_id_cdrom_id_SOURCES = extras/cdrom_id/cdrom_id.c
248 extras_cdrom_id_cdrom_id_LDADD = libudev/libudev-private.la
249 libexec_PROGRAMS += extras/cdrom_id/cdrom_id
250 dist_udevrules_DATA += extras/cdrom_id/60-cdrom_id.rules
252 # ------------------------------------------------------------------------------
253 # collect - trigger action when a collection of devices appeared
254 # ------------------------------------------------------------------------------
255 extras_collect_collect_SOURCES = extras/collect/collect.c
256 extras_collect_collect_LDADD = libudev/libudev-private.la
257 libexec_PROGRAMS += extras/collect/collect
259 # ------------------------------------------------------------------------------
260 # edd_id - BIOS EDD block device match
261 # ------------------------------------------------------------------------------
262 extras_edd_id_edd_id_SOURCES = extras/edd_id/edd_id.c
263 extras_edd_id_edd_id_LDADD = libudev/libudev-private.la
264 libexec_PROGRAMS += extras/edd_id/edd_id
265 dist_udevrules_DATA += extras/edd_id/61-persistent-storage-edd.rules
267 # ------------------------------------------------------------------------------
268 # create_floppy_devices - historical floppy kernel device nodes (/dev/fd0h1440, ...)
269 # ------------------------------------------------------------------------------
270 extras_floppy_create_floppy_devices_SOURCES = extras/floppy/create_floppy_devices.c
271 extras_floppy_create_floppy_devices_LDADD = libudev/libudev-private.la
272 libexec_PROGRAMS += extras/floppy/create_floppy_devices
273 dist_udevrules_DATA += extras/floppy/60-floppy.rules
275 # ------------------------------------------------------------------------------
276 # input_id - import input device class
277 # ------------------------------------------------------------------------------
278 extras_input_id_input_id_SOURCES = extras/input_id/input_id.c
279 extras_input_id_input_id_LDADD = libudev/libudev-private.la
280 libexec_PROGRAMS += extras/input_id/input_id
282 # ------------------------------------------------------------------------------
283 # path_id - compose identifier of persistent elements of the parent buses
284 # ------------------------------------------------------------------------------
285 extras_path_id_path_id_SOURCES = extras/path_id/path_id.c
286 extras_path_id_path_id_LDADD = libudev/libudev-private.la
287 libexec_PROGRAMS += extras/path_id/path_id
289 # ------------------------------------------------------------------------------
290 # scsi_id - SCSI inquiry to get various serial numbers
291 # ------------------------------------------------------------------------------
292 extras_scsi_id_scsi_id_SOURCES =\
293 extras/scsi_id/scsi_id.c \
294 extras/scsi_id/scsi_serial.c \
295 extras/scsi_id/scsi.h \
296 extras/scsi_id/scsi_id.h
297 extras_scsi_id_scsi_id_LDADD = libudev/libudev-private.la
298 libexec_PROGRAMS += extras/scsi_id/scsi_id
299 dist_man_MANS += extras/scsi_id/scsi_id.8
301 # ------------------------------------------------------------------------------
302 # usb_id - USB device property import
303 # ------------------------------------------------------------------------------
304 extras_usb_id_usb_id_SOURCES = extras/usb_id/usb_id.c
305 extras_usb_id_usb_id_LDADD = libudev/libudev-private.la
306 libexec_PROGRAMS += extras/usb_id/usb_id
308 # ------------------------------------------------------------------------------
309 # v4l_id - video4linux capabilities
310 # ------------------------------------------------------------------------------
311 extras_v4l_id_v4l_id_SOURCES = extras/v4l_id/v4l_id.c
312 extras_v4l_id_v4l_id_LDADD = libudev/libudev-private.la
313 libexec_PROGRAMS += extras/v4l_id/v4l_id
314 dist_udevrules_DATA += extras/v4l_id/60-persistent-v4l.rules
316 # ------------------------------------------------------------------------------
317 # qemu -- qemu/kvm guest tweaks
318 # ------------------------------------------------------------------------------
319 dist_udevrules_DATA += extras/qemu/42-qemu-usb.rules
322 # ------------------------------------------------------------------------------
323 # conditional extras (need glib, libusb, libacl, ...)
324 # ------------------------------------------------------------------------------
325 dist_udevrules_DATA += \
326 rules/rules.d/75-net-description.rules \
327 rules/rules.d/75-tty-description.rules \
328 rules/rules.d/78-sound-card.rules
330 # ------------------------------------------------------------------------------
331 # GUdev - libudev gobject interface
332 # ------------------------------------------------------------------------------
337 SUBDIRS += extras/gudev/docs
339 libgudev_includedir=$(includedir)/gudev-1.0/gudev
340 libgudev_include_HEADERS = \
341 extras/gudev/gudev.h \
342 extras/gudev/gudevenums.h \
343 extras/gudev/gudevenumtypes.h \
344 extras/gudev/gudevtypes.h \
345 extras/gudev/gudevclient.h \
346 extras/gudev/gudevdevice.h \
347 extras/gudev/gudevenumerator.h
349 lib_LTLIBRARIES += extras/gudev/libgudev-1.0.la
350 pkgconfig_DATA += extras/gudev/gudev-1.0.pc
352 extras_gudev_libgudev_1_0_la_SOURCES = \
353 extras/gudev/gudevenums.h \
354 extras/gudev/gudevenumtypes.h \
355 extras/gudev/gudevenumtypes.h\
356 extras/gudev/gudevtypes.h \
357 extras/gudev/gudevclient.h \
358 extras/gudev/gudevclient.c \
359 extras/gudev/gudevdevice.h \
360 extras/gudev/gudevdevice.c \
361 extras/gudev/gudevenumerator.h \
362 extras/gudev/gudevenumerator.c \
363 extras/gudev/gudevprivate.h
365 dist_extras_gudev_libgudev_1_0_la_SOURCES = \
366 extras/gudev/gudevmarshal.h \
367 extras/gudev/gudevmarshal.c \
368 extras/gudev/gudevenumtypes.h \
369 extras/gudev/gudevenumtypes.c
370 BUILT_SOURCES = $(dist_extras_gudev_libgudev_1_0_la_SOURCES)
372 extras_gudev_libgudev_1_0_la_CPPFLAGS = \
374 -I$(top_builddir)/extras \
375 -I$(top_srcdir)/extras \
376 -I$(top_builddir)/extras/gudev \
377 -I$(top_srcdir)/extras/gudev \
378 -D_POSIX_PTHREAD_SEMANTICS -D_REENTRANT \
379 -D_GUDEV_COMPILATION \
380 -DG_LOG_DOMAIN=\"GUdev\"
381 extras_gudev_libgudev_1_0_la_CFLAGS = $(GLIB_CFLAGS)
382 extras_gudev_libgudev_1_0_la_LIBADD = libudev/libudev.la $(GLIB_LIBS)
384 extras_gudev_libgudev_1_0_la_LDFLAGS = \
385 -version-info $(LIBGUDEV_CURRENT):$(LIBGUDEV_REVISION):$(LIBGUDEV_AGE) \
386 -export-dynamic -no-undefined \
387 -export-symbols-regex '^g_udev_.*'
390 extras/gudev/COPYING \
391 extras/gudev/gudevmarshal.list \
392 extras/gudev/gudevenumtypes.h.template \
393 extras/gudev/gudevenumtypes.c.template
395 extras/gudev/gudevmarshal.h: extras/gudev/gudevmarshal.list
396 $(AM_V_GEN)glib-genmarshal $< --prefix=g_udev_marshal --header > $@
398 extras/gudev/gudevmarshal.c: extras/gudev/gudevmarshal.list
399 $(AM_V_GEN)echo "#include \"gudevmarshal.h\"" > $@ && \
400 glib-genmarshal $< --prefix=g_udev_marshal --body >> $@
402 extras/gudev/gudevenumtypes.h: extras/gudev/gudevenumtypes.h.template extras/gudev/gudevenums.h
403 $(AM_V_GEN)glib-mkenums --template $^ > \
404 $@.tmp && mv $@.tmp $@
406 extras/gudev/gudevenumtypes.c: extras/gudev/gudevenumtypes.c.template extras/gudev/gudevenums.h
407 $(AM_V_GEN)glib-mkenums --template $^ > \
408 $@.tmp && mv $@.tmp $@
410 if ENABLE_INTROSPECTION
411 extras/gudev/GUdev-1.0.gir: extras/gudev/libgudev-1.0.la $(G_IR_SCANNER) Makefile.am
412 $(AM_V_GEN)PKG_CONFIG_PATH=$(top_builddir)/data:$$PKG_CONFIG_PATH \
413 LD_LIBRARY_PATH=$(top_builddir)/extras/gudev:$$LD_LIBRARY_PATH \
417 --include=GObject-2.0 \
418 --library=gudev-1.0 \
419 --library-path=extras/gudev \
423 -I$(top_builddir)/extras \
424 -I$(top_srcdir)/extras \
425 -D_GUDEV_COMPILATION \
426 -D_GUDEV_WORK_AROUND_DEV_T_BUG \
427 $(top_srcdir)/extras/gudev/gudev.h \
428 $(top_srcdir)/extras/gudev/gudevtypes.h \
429 $(top_srcdir)/extras/gudev/gudevenums.h \
430 $(or $(wildcard $(top_builddir)/extras/gudev/gudevenumtypes.h),$(top_srcdir)/extras/gudev/gudevenumtypes.h) \
431 $(top_srcdir)/extras/gudev/gudevclient.h \
432 $(top_srcdir)/extras/gudev/gudevdevice.h \
433 $(top_srcdir)/extras/gudev/gudevenumerator.h \
434 $(top_srcdir)/extras/gudev/gudevclient.c \
435 $(top_srcdir)/extras/gudev/gudevdevice.c \
436 $(top_srcdir)/extras/gudev/gudevenumerator.c
438 extras/gudev/GUdev-1.0.typelib: extras/gudev/GUdev-1.0.gir $(G_IR_COMPILER)
439 $(AM_V_GEN)g-ir-compiler $< -o $@
442 gir_DATA = extras/gudev/GUdev-1.0.gir
444 typelibsdir = $(GIRTYPELIBDIR)
445 typelibs_DATA = extras/gudev/GUdev-1.0.typelib
447 CLEANFILES += $(gir_DATA) $(typelibs_DATA)
448 endif # ENABLE_INTROSPECTION
450 # move lib from $(libdir) to $(rootlib_execdir) and update devel link, if needed
451 libgudev-install-move-hook:
452 if test "$(libdir)" != "$(rootlib_execdir)"; then \
453 mkdir -p $(DESTDIR)$(rootlib_execdir) && \
454 so_img_name=$$(readlink $(DESTDIR)$(libdir)/libgudev-1.0.so) && \
455 so_img_rel_target_prefix=$$(echo $(libdir) | sed 's,\(^/\|\)[^/][^/]*,..,g') && \
456 ln -sf $$so_img_rel_target_prefix$(rootlib_execdir)/$$so_img_name $(DESTDIR)$(libdir)/libgudev-1.0.so && \
457 mv $(DESTDIR)$(libdir)/libgudev-1.0.so.* $(DESTDIR)$(rootlib_execdir); \
460 libgudev-uninstall-move-hook:
461 rm -f $(DESTDIR)$(rootlib_execdir)/libgudev-1.0.so*
463 INSTALL_EXEC_HOOKS += libgudev-install-move-hook
464 UNINSTALL_EXEC_HOOKS += libgudev-uninstall-move-hook
466 # ------------------------------------------------------------------------------
467 # Bluetooth HID devices with special magic to switch the device
468 # ------------------------------------------------------------------------------
469 extras_hid2hci_hid2hci_SOURCES = extras/hid2hci/hid2hci.c
470 extras_hid2hci_hid2hci_CPPFLAGS = $(AM_CPPFLAGS) $(LIBUSB_CFLAGS)
471 extras_hid2hci_hid2hci_LDADD = libudev/libudev-private.la $(LIBUSB_LIBS)
472 dist_udevrules_DATA += extras/hid2hci/70-hid2hci.rules
473 libexec_PROGRAMS += extras/hid2hci/hid2hci
475 # ------------------------------------------------------------------------------
476 # udev_acl - apply ACLs for users with local forground sessions
477 # ------------------------------------------------------------------------------
478 extras_udev_acl_udev_acl_SOURCES = extras/udev-acl/udev-acl.c
479 extras_udev_acl_udev_acl_CPPFLAGS = $(AM_CPPFLAGS) $(GLIB_CFLAGS)
480 extras_udev_acl_udev_acl_LDADD = libudev/libudev-private.la -lacl $(GLIB_LIBS)
481 dist_udevrules_DATA += extras/udev-acl/70-acl.rules
482 libexec_PROGRAMS += extras/udev-acl/udev-acl
484 udevacl-install-hook:
485 mkdir -p $(DESTDIR)$(prefix)/lib/ConsoleKit/run-seat.d
486 ln -sf $(libexecdir)/udev-acl $(DESTDIR)$(prefix)/lib/ConsoleKit/run-seat.d/udev-acl.ck
488 INSTALL_EXEC_HOOKS += udevacl-install-hook
490 # ------------------------------------------------------------------------------
491 # usb-db - read USB vendor/device string database
492 # ------------------------------------------------------------------------------
493 extras_usb_db_usb_db_SOURCES = extras/usb-db/usb-db.c
494 extras_usb_db_usb_db_CPPFLAGS = $(AM_CPPFLAGS) -DUSB_DATABASE=\"$(USB_DATABASE)\" -DBUILD_FOR_USB
495 extras_usb_db_usb_db_LDADD = libudev/libudev-private.la
496 libexec_PROGRAMS += extras/usb-db/usb-db
498 # ------------------------------------------------------------------------------
499 # pci-db - read PCI vendor/device string database
500 # ------------------------------------------------------------------------------
501 extras_usb_db_pci_db_SOURCES = extras/usb-db/usb-db.c
502 extras_usb_db_pci_db_CPPFLAGS = $(AM_CPPFLAGS) -DPCI_DATABASE=\"$(PCI_DATABASE)\" -DBUILD_FOR_PCI
503 extras_usb_db_pci_db_LDADD = libudev/libudev-private.la
504 libexec_PROGRAMS += extras/usb-db/pci-db
506 # ------------------------------------------------------------------------------
507 # mobile-action-modeswitch - switch Mobile Action cables into serial mode
508 # ------------------------------------------------------------------------------
509 extras_mobile_action_modeswitch_mobile_action_modeswitch_SOURCES =\
510 extras/mobile-action-modeswitch/mobile-action-modeswitch.c \
511 extras/mobile-action-modeswitch/utils.c \
512 extras/mobile-action-modeswitch/utils.h \
513 extras/mobile-action-modeswitch/ma8280p_us.c \
514 extras/mobile-action-modeswitch/ma8280p_us.h
515 extras_mobile_action_modeswitch_mobile_action_modeswitch_CPPFLAGS = $(AM_CPPFLAGS) $(LIBUSB_CFLAGS)
516 extras_mobile_action_modeswitch_mobile_action_modeswitch_LDADD = libudev/libudev-private.la $(LIBUSB_LIBS)
518 dist_udevrules_DATA += \
519 extras/mobile-action-modeswitch/61-mobile-action.rules
521 libexec_PROGRAMS += extras/mobile-action-modeswitch/mobile-action-modeswitch
523 # ------------------------------------------------------------------------------
524 # mtd_probe - autoloads FTL module for mtd devices
525 # ------------------------------------------------------------------------------
526 extras_mtd_probe_mtd_probe_SOURCES = \
527 extras/mtd_probe/mtd_probe.c \
528 extras/mtd_probe/mtd_probe.h \
529 extras/mtd_probe/probe_smartmedia.c
531 extras_mtd_probe_mtd_probe_CPPFLAGS = $(AM_CPPFLAGS)
533 dist_udevrules_DATA += extras/mtd_probe/75-probe_mtd.rules
535 libexec_PROGRAMS += extras/mtd_probe/mtd_probe
538 # ------------------------------------------------------------------------------
539 # keymap - map custom hardware's multimedia keys
540 # ------------------------------------------------------------------------------
541 extras_keymap_keymap_SOURCES = extras/keymap/keymap.c
542 extras_keymap_keymap_CPPFLAGS = $(AM_CPPFLAGS) -I extras/keymap
543 nodist_extras_keymap_keymap_SOURCES = \
544 extras/keymap/keys-from-name.h \
545 extras/keymap/keys-to-name.h
546 BUILT_SOURCES += $(nodist_extras_keymap_keymap_SOURCES)
548 EXTRA_DIST += extras/keymap/check-keymaps.sh
549 dist_udevrules_DATA += extras/keymap/95-keymap.rules
550 dist_udevrules_DATA += extras/keymap/95-keyboard-force-release.rules
551 libexec_PROGRAMS += extras/keymap/keymap
552 dist_libexec_SCRIPTS += extras/keymap/findkeyboards
553 dist_libexec_SCRIPTS += extras/keymap/keyboard-force-release.sh
554 dist_doc_DATA = extras/keymap/README.keymap.txt
557 extras/keymap/keys.txt \
558 extras/keymap/keys-from-name.gperf
560 udevkeymapdir = $(libexecdir)/keymaps
561 dist_udevkeymap_DATA = \
562 extras/keymap/keymaps/acer \
563 extras/keymap/keymaps/acer-aspire_5720 \
564 extras/keymap/keymaps/acer-aspire_8930 \
565 extras/keymap/keymaps/acer-aspire_5920g \
566 extras/keymap/keymaps/acer-aspire_6920 \
567 extras/keymap/keymaps/acer-travelmate_c300 \
568 extras/keymap/keymaps/asus \
569 extras/keymap/keymaps/compaq-e_evo \
570 extras/keymap/keymaps/dell \
571 extras/keymap/keymaps/dell-latitude-xt2 \
572 extras/keymap/keymaps/everex-xt5000 \
573 extras/keymap/keymaps/fujitsu-amilo_pa_2548 \
574 extras/keymap/keymaps/fujitsu-amilo_pro_edition_v3505 \
575 extras/keymap/keymaps/fujitsu-amilo_pro_v3205 \
576 extras/keymap/keymaps/fujitsu-amilo_si_1520 \
577 extras/keymap/keymaps/fujitsu-esprimo_mobile_v5 \
578 extras/keymap/keymaps/fujitsu-esprimo_mobile_v6 \
579 extras/keymap/keymaps/hewlett-packard \
580 extras/keymap/keymaps/hewlett-packard-2510p_2530p \
581 extras/keymap/keymaps/hewlett-packard-compaq_elitebook \
582 extras/keymap/keymaps/hewlett-packard-pavilion \
583 extras/keymap/keymaps/hewlett-packard-presario-2100 \
584 extras/keymap/keymaps/hewlett-packard-tablet \
585 extras/keymap/keymaps/hewlett-packard-tx2 \
586 extras/keymap/keymaps/ibm-thinkpad-usb-keyboard-trackpoint \
587 extras/keymap/keymaps/inventec-symphony_6.0_7.0 \
588 extras/keymap/keymaps/lenovo-3000 \
589 extras/keymap/keymaps/lenovo-ideapad \
590 extras/keymap/keymaps/lenovo-thinkpad-usb-keyboard-trackpoint \
591 extras/keymap/keymaps/lenovo-thinkpad_x6_tablet \
592 extras/keymap/keymaps/lenovo-thinkpad_x200_tablet \
593 extras/keymap/keymaps/lg-x110 \
594 extras/keymap/keymaps/logitech-wave \
595 extras/keymap/keymaps/logitech-wave-cordless \
596 extras/keymap/keymaps/logitech-wave-pro-cordless \
597 extras/keymap/keymaps/maxdata-pro_7000 \
598 extras/keymap/keymaps/medion-fid2060 \
599 extras/keymap/keymaps/medionnb-a555 \
600 extras/keymap/keymaps/micro-star \
601 extras/keymap/keymaps/module-asus-w3j \
602 extras/keymap/keymaps/module-ibm \
603 extras/keymap/keymaps/module-lenovo \
604 extras/keymap/keymaps/module-sony \
605 extras/keymap/keymaps/module-sony-old \
606 extras/keymap/keymaps/module-sony-vgn \
607 extras/keymap/keymaps/olpc-xo \
608 extras/keymap/keymaps/onkyo \
609 extras/keymap/keymaps/oqo-model2 \
610 extras/keymap/keymaps/samsung-other \
611 extras/keymap/keymaps/samsung-sq1us \
612 extras/keymap/keymaps/samsung-sx20s \
613 extras/keymap/keymaps/toshiba-satellite_a100 \
614 extras/keymap/keymaps/toshiba-satellite_a110 \
615 extras/keymap/keymaps/toshiba-satellite_m30x \
616 extras/keymap/keymaps/zepto-znote
618 udevkeymapforcereldir = $(libexecdir)/keymaps/force-release
619 dist_udevkeymapforcerel_DATA = \
620 extras/keymap/force-release-maps/dell-touchpad \
621 extras/keymap/force-release-maps/hp-other \
622 extras/keymap/force-release-maps/samsung-other \
623 extras/keymap/force-release-maps/common-volume-keys
625 extras/keymap/keys.txt: $(INCLUDE_PREFIX)/linux/input.h
626 $(AM_V_at)mkdir -p extras/keymap
627 $(AM_V_GEN)$(AWK) '/^#define.*KEY_[^ ]+[ \t]+[0-9]/ { if ($$2 != "KEY_MAX") { print $$2 } }' < $< | sed 's/^KEY_COFFEE$$/KEY_SCREENLOCK/' > $@
629 extras/keymap/keys-from-name.gperf: extras/keymap/keys.txt
630 $(AM_V_GEN)$(AWK) 'BEGIN{ print "struct key { const char* name; unsigned short id; };"; print "%null-strings"; print "%%";} { print $$1 ", " $$1 }' < $< > $@
632 extras/keymap/keys-from-name.h: extras/keymap/keys-from-name.gperf Makefile
633 $(AM_V_GEN)$(GPERF) -L ANSI-C -t --ignore-case -N lookup_key -H hash_key_name -p -C < $< > $@
635 extras/keymap/keys-to-name.h: extras/keymap/keys.txt Makefile
636 $(AM_V_GEN)$(AWK) 'BEGIN{ print "const char* const key_names[KEY_CNT] = { "} { print "[" $$1 "] = \"" $$1 "\"," } END{print "};"}' < $< > $@
638 keymaps-distcheck-hook: extras/keymap/keys.txt
639 $(top_srcdir)/extras/keymap/check-keymaps.sh $(top_srcdir) $^
640 DISTCHECK_HOOKS += keymaps-distcheck-hook
642 endif # ENABLE_EXTRAS
644 # ------------------------------------------------------------------------------
645 # install, uninstall, clean hooks
646 # ------------------------------------------------------------------------------
648 rm -rf udev-test-install
651 rm -rf autom4te.cache
654 udev-$(VERSION).tar.gz \
655 udev-$(VERSION).tar.bz2 \
658 EXTRA_DIST += $(TESTS)
659 EXTRA_DIST += test/rule-syntax-check.py
661 install-exec-hook: $(INSTALL_EXEC_HOOKS)
663 install-data-hook: $(INSTALL_DATA_HOOKS)
665 uninstall-hook: $(UNINSTALL_EXEC_HOOKS)
667 distcheck-hook: $(DISTCHECK_HOOKS)
669 # ------------------------------------------------------------------------------
670 # custom release helpers
671 # ------------------------------------------------------------------------------
672 PREVIOUS_VERSION = `expr $(VERSION) - 1`
674 @ head -1 ChangeLog | grep -q "to v$(PREVIOUS_VERSION)"
675 @ mv ChangeLog ChangeLog.tmp
676 @ echo "Summary of changes from v$(PREVIOUS_VERSION) to v$(VERSION)" >> ChangeLog
677 @ echo "============================================" >> ChangeLog
679 @ git log --pretty=short $(PREVIOUS_VERSION)..HEAD | git shortlog >> ChangeLog
682 @ cat ChangeLog.tmp >> ChangeLog
686 rm -rf $(PWD)/udev-test-install/
687 make DESTDIR=$(PWD)/udev-test-install install
688 tree $(PWD)/udev-test-install/
691 head -1 ChangeLog | grep -q "to v$(VERSION)"
692 head -1 NEWS | grep -q "udev $(VERSION)"
693 git commit -a -m "release $(VERSION)"
694 cat .git/refs/heads/master > .git/refs/tags/$(VERSION)
699 rsync -av udev/*.html master.kernel.org:/pub/linux/utils/kernel/hotplug/udev/
700 rsync -av --delete libudev/docs/html/ master.kernel.org:/pub/linux/utils/kernel/hotplug/libudev/
701 rsync -av --delete extras/gudev/docs/html/ master.kernel.org:/pub/linux/utils/kernel/hotplug/gudev/