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 # Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
27 # Path to the base of the uts directory tree (usually /usr/src/uts).
32 # Define the module and object file sets.
35 OBJECTS
= $(SOL_OFS_OBJS
:%=$(OBJS_DIR
)/%)
36 LINTS
= $(SOL_OFS_OBJS
:%.o
=$(LINTS_DIR
)/%.ln
)
37 ROOTMODULE
= $(ROOT_MISC_DIR
)/$(MODULE
)
38 LDFLAGS
+= -dy
-Nmisc
/ibtl
-Nmisc
/ibcm
39 WARLOCK_OUT
= $(SOL_OFS
:%.o
=%.ll
)
40 WARLOCK_OK
= $(MODULE
).ok
41 WLCMD_DIR
= $(UTSBASE
)/common
/io
/warlock
43 # Include common rules.
45 include $(UTSBASE
)/intel
/Makefile.intel
50 ALL_TARGET
= $(BINARY
)
51 LINT_TARGET
= $(MODULE
).lint
52 INSTALL_TARGET
= $(BINARY
) $(ROOTMODULE
)
55 # For now, disable these lint checks; maintainers should endeavor
56 # to investigate and remove these for maximum lint coverage.
57 # Please do not carry these forward to new Makefiles.
59 LINTTAGS
+= -erroff
=E_BAD_PTR_CAST_ALIGN
60 LINTTAGS
+= -erroff
=E_PTRDIFF_OVERFLOW
61 LINTTAGS
+= -erroff
=E_STATIC_UNUSED
62 LINTTAGS
+= -erroff
=E_CONST_TRUNCATED_BY_ASSIGN
64 CERRWARN
+= -_gcc
=-Wno-uninitialized
65 CERRWARN
+= -_gcc
=-Wno-parentheses
66 CERRWARN
+= -_gcc
=-Wno-type-limits
67 CERRWARN
+= -_gcc
=-Wno-unused-variable
70 # Default build targets.
79 $(RM
) $(WARLOCK_OUT
) $(WARLOCK_OK
)
81 clobber: $(CLOBBER_DEPS
)
82 $(RM
) $(WARLOCK_OUT
) $(WARLOCK_OK
)
86 modlintlib
: $(MODLINTLIB_DEPS
)
88 clean.lint
: $(CLEAN_LINT_DEPS
)
90 install: $(INSTALL_DEPS
)
93 # Include common targets.
95 include $(UTSBASE
)/intel
/Makefile.targ
98 # Defines for local commands.
105 warlock
: $(WARLOCK_OK
)
107 $(WARLOCK_OK
): $(WARLOCK_OUT
) $(WLCMD_DIR
)/sol_ofs.wlcmd warlock_ddi.files
108 $(WARLOCK
) -c
$(WLCMD_DIR
)/sol_ofs.wlcmd
$(WARLOCK_OUT
) \
109 -l ..
/warlock
/ddi_dki_impl.ll
112 %.ll
: $(UTSBASE
)/common
/io
/ib
/clients
/of
/sol_ofs
/%.c \
113 $(UTSBASE
)/common
/sys
/ib
/clients
/of
/sol_ofs
/sol_uverbs.h
114 $(WLCC
) $(CPPFLAGS
) -DDEBUG
-o
$@
$<
117 @cd ..
/warlock
; pwd
; $(MAKE
) warlock