xref: /titanic_44/usr/src/uts/sparc/usbecm/Makefile (revision e2c88f0c2610f16de7b639746b40dea5f3e2256e)
1 #
2 # CDDL HEADER START
3 #
4 # The contents of this file are subject to the terms of the
5 # Common Development and Distribution License (the "License").
6 # You may not use this file except in compliance with the License.
7 #
8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 # or http://www.opensolaris.org/os/licensing.
10 # See the License for the specific language governing permissions
11 # and limitations under the License.
12 #
13 # When distributing Covered Code, include this CDDL HEADER in each
14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 # If applicable, add the following below this CDDL HEADER, with the
16 # fields enclosed by brackets "[]" replaced with your own identifying
17 # information: Portions Copyright [yyyy] [name of copyright owner]
18 #
19 # CDDL HEADER END
20 #
21 #
22 # uts/sparc/usbecm/Makefile
23 # Copyright 2010 Sun Microsystems, Inc.  All rights reserved.
24 # Use is subject to license terms.
25 #
26 # Copyright 2014 Garrett D'Amore <garrett@damore.org>
27 #
28 #	This makefile drives the production of Abstract Control Model of
29 #	USB Communication Devices Class dirver.
30 #
31 #	Path to the base of the uts directory tree (usually /usr/src/uts).
32 #
33 UTSBASE	= ../..
34 
35 #
36 #	Define the module and object file sets.
37 #
38 MODULE		= usbecm
39 OBJECTS		= $(USBECM_OBJS:%=$(OBJS_DIR)/%)
40 LINTS		= $(USBECM_OBJS:%.o=$(LINTS_DIR)/%.ln)
41 ROOTMODULE	= $(ROOT_DRV_DIR)/$(MODULE)
42 WARLOCK_OUT	= $(USBECM_OBJS:%.o=%.ll)
43 WARLOCK_OK	= $(MODULE).ok
44 WLCMD_DIR	= $(UTSBASE)/common/io/warlock
45 
46 #
47 #	Include common rules.
48 #
49 include $(UTSBASE)/sparc/Makefile.sparc
50 
51 LDFLAGS         += -dy -Nmisc/usba -Nmisc/mac
52 
53 #
54 # lint pass one enforcement
55 #
56 CFLAGS += $(CCVERBOSE)
57 
58 #
59 #	Define targets
60 #
61 ALL_TARGET	= $(BINARY)
62 LINT_TARGET	= $(MODULE).lint
63 INSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
64 
65 .KEEP_STATE:
66 
67 all:		$(ALL_DEPS)
68 
69 def:		$(DEF_DEPS)
70 
71 clean:		$(CLEAN_DEPS)
72 		$(RM) $(WARLOCK_OUT) $(WARLOCK_OK)
73 
74 clobber:	$(CLOBBER_DEPS)
75 		$(RM) $(WARLOCK_OUT) $(WARLOCK_OK)
76 
77 lint:		$(LINT_DEPS)
78 
79 modlintlib:	$(MODLINTLIB_DEPS)
80 
81 clean.lint:	$(CLEAN_LINT_DEPS)
82 
83 install:	$(INSTALL_DEPS)
84 
85 #
86 #	Include common targets.
87 #
88 include $(UTSBASE)/sparc/Makefile.targ
89 
90 #
91 #	Defines for local commands.
92 #
93 WLCC		= wlcc
94 TOUCH		= touch
95 WARLOCK		= warlock
96 TEST		= test
97 
98 #
99 #	warlock
100 #
101 WARLOCK_CMD	= $(WLCMD_DIR)/$(MODULE).wlcmd
102 
103 UHCI_FILES = $(UHCI_OBJS:%.o=../uhci/%.ll)
104 OHCI_FILES = $(OHCI_OBJS:%.o=../ohci/%.ll)
105 EHCI_FILES = $(EHCI_OBJS:%.o=../ehci/%.ll)
106 
107 warlock: $(WARLOCK_OK) warlock_with_usba
108 
109 %.ll: $(UTSBASE)/common/io/usb/clients/usbecm/%.c
110 	$(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $<
111 
112 $(WARLOCK_OK): $(WARLOCK_OUT) $(WLCMD_DIR)/usbecm.wlcmd warlock_ddi.files
113 	$(WARLOCK) -c $(WLCMD_DIR)/usbecm.wlcmd $(WARLOCK_OUT)  \
114 		-l ../warlock/ddi_dki_impl.ll
115 	$(TOUCH) $@
116 
117 warlock_with_usba: $(WLCMD_DIR)/usbecm_with_usba.wlcmd $(WARLOCK_OUT) \
118 	usba_files ohci_files uhci_files ehci_files \
119 	warlock_ddi.files
120 	$(WARLOCK) -c $(WLCMD_DIR)/usbecm_with_usba.wlcmd \
121 		$(USBA_FILES) $(OHCI_FILES) $(EHCI_FILES) $(UHCI_FILES) \
122 		$(WARLOCK_OUT) -l ../warlock/ddi_dki_impl.ll
123 
124 usba_files:
125 	@cd ../usba;pwd; $(MAKE) warlock
126 
127 uhci_files:
128 	@cd ../uhci;pwd; $(MAKE) warlock
129 
130 ohci_files:
131 	@cd ../ohci;pwd; $(MAKE) warlock
132 
133 ehci_files:
134 	@cd ../ehci;pwd; $(MAKE) warlock
135 
136 warlock_ddi.files:
137 	cd ../warlock; pwd; $(MAKE) warlock
138