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.
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.
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]
22 # uts/sparc/ugen/Makefile
24 # Copyright 2009 Sun Microsystems, Inc. All rights reserved.
25 # Use is subject to license terms.
27 # Copyright 2014 Garrett D'Amore <garrett@damore.org>
29 # This makefile drives the production of the ugen kernel driver.
31 # sparc architecture dependent
35 # Path to the base of the uts directory tree (usually /usr/src/uts).
40 # Define the module and object file sets.
43 OBJECTS
= $(UGEN_OBJS
:%=$(OBJS_DIR
)/%)
44 LINTS
= $(UGEN_OBJS
:%.o
=$(LINTS_DIR
)/%.ln
)
45 ROOTMODULE
= $(ROOT_DRV_DIR
)/$(MODULE
)
46 WARLOCK_OUT
= $(UGEN_OBJS
:%.o
=%.ll
)
47 WARLOCK_OK
= $(MODULE
).ok
48 WLCMD_DIR
= $(UTSBASE
)/common
/io
/warlock
51 # Include common rules.
53 include $(UTSBASE
)/sparc
/Makefile.sparc
56 # lint pass one enforcement
58 CFLAGS
+= $(CCVERBOSE
)
59 CERRWARN
+= -_gcc
=-Wno-uninitialized
62 # depends on misc/usba
64 LDFLAGS
+= -dy
-Nmisc
/usba
69 ALL_TARGET
= $(BINARY
)
70 LINT_TARGET
= $(MODULE
).lint
71 INSTALL_TARGET
= $(BINARY
) $(ROOTMODULE
)
80 $(RM
) $(WARLOCK_OUT
) $(WARLOCK_OK
)
82 clobber: $(CLOBBER_DEPS
)
83 $(RM
) $(WARLOCK_OUT
) $(WARLOCK_OK
)
87 modlintlib
: $(MODLINTLIB_DEPS
)
89 clean.lint
: $(CLEAN_LINT_DEPS
)
91 install: $(INSTALL_DEPS
)
94 # Include common targets.
96 include $(UTSBASE
)/sparc
/Makefile.targ
99 # Defines for local commands.
109 USBA_FILES
= $(USBA_OBJS
:%.o
=..
/usba
/%.ll
)
110 UHCI_FILES
= $(UHCI_OBJS
:%.o
=..
/uhci
/%.ll
)
111 OHCI_FILES
= $(OHCI_OBJS
:%.o
=..
/ohci
/%.ll
)
112 EHCI_FILES
= $(EHCI_OBJS
:%.o
=..
/ehci
/%.ll
)
114 warlock
: $(WARLOCK_OK
) warlock_with_usba
116 $(WARLOCK_OK
): $(WARLOCK_OUT
) $(WLCMD_DIR
)/ugen.wlcmd warlock_ddi.files
117 $(WARLOCK
) -c
$(WLCMD_DIR
)/ugen.wlcmd
$(WARLOCK_OUT
) \
118 -l ..
/warlock
/ddi_dki_impl.ll
121 %.ll
: $(UTSBASE
)/common
/io
/usb
/clients
/ugen
/%.c \
122 $(UTSBASE
)/common
/sys
/usb
/clients
/ugen
/ugend.h
123 $(WLCC
) $(CPPFLAGS
) -DDEBUG
-o
$@
$<
126 warlock_with_usba
: $(WLCMD_DIR
)/ugen_with_usba.wlcmd
$(WARLOCK_OUT
) \
127 usba_files ohci_files ehci_files uhci_files warlock_ddi.files
128 $(WARLOCK
) -c
$(WLCMD_DIR
)/ugen_with_usba.wlcmd \
129 $(USBA_FILES
) $(OHCI_FILES
) $(EHCI_FILES
) $(UHCI_FILES
) \
131 -l ..
/warlock
/ddi_dki_impl.ll
134 @cd ..
/usba
;pwd
; $(MAKE
) warlock
137 @cd ..
/uhci
;pwd
; $(MAKE
) warlock
140 @cd ..
/ohci
;pwd
; $(MAKE
) warlock
143 @cd ..
/ehci
;pwd
; $(MAKE
) warlock
146 cd ..
/warlock
; pwd
; $(MAKE
) warlock