xref: /titanic_41/usr/src/uts/intel/i915/Makefile (revision 5ce5f3670f7934e376808da0d1309924ecf8f9e5)
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#
23# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26# ident	"%Z%%M%	%I%	%E% SMI"
27#
28# uts/intel/drm_i915/Makefile
29#
30#	This makefile drives the production of i915 graphics device driver,
31#	which supports the DRI (Direct Rendering Infrastructure), with the help
32#	of drm common misc module.
33#
34#	intel platform dependent
35#
36#	Path to the base of the uts directory tree (usually /usr/src/uts).
37#
38UTSBASE = ../..
39
40#
41#	Define the module and object file sets.
42#
43MODULE		= i915
44OBJECTS		= $(I915_OBJS:%=$(OBJS_DIR)/%)
45LINTS		= $(I915_OBJS:%.o=$(LINTS_DIR)/%.ln)
46ROOTMODULE	= $(ROOT_DRV_DIR)/$(MODULE)
47I915_DRV_O	= $(OBJS_DIR)/i915_drv.o
48I915_DRV_C	= $(PSM_DRM_SRC)/i915_drv.c
49DRM_PCIIDS_H	= $(CMN_DRM_SRC)/drm_pciids.h
50DRM_PCIIDS_TXT	= $(CMN_DRM_SRC)/drm_pciids.txt
51CREATE_SUNOS_PCI_LISTS_SH	= $(CMN_DRM_SRC)/create_sunos_pci_lists.sh
52
53# i915 driver depends on drm, agpmaster and gfx_private misc modules
54INC_PATH        += -I$(UTSBASE)/intel/io/drm \
55		   -I$(UTSBASE)/common/io/drm \
56		   -I$(UTSBASE)/intel/io/agpmaster \
57		   -I$(UTSBASE)/i86pc/io/gfx_private
58
59PSM_DRM_SRC	= $(UTSBASE)/intel/io/drm
60CMN_DRM_SRC	= $(UTSBASE)/common/io/drm
61
62#
63#	dependency
64LDFLAGS	+= -dy -Nmisc/drm -Nmisc/agpmaster -Nmisc/gfx_private \
65	   -Nmisc/pci_autoconfig
66
67#
68#	Include common rules.
69#
70include $(UTSBASE)/intel/Makefile.intel
71
72#
73#	Re-define targets to add drm_pciids.h dependency
74#
75ALL_TARGET	= $(DRM_PCIIDS_H) $(BINARY)
76LINT_TARGET	= $(MODULE).lint
77INSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
78
79CLEANFILES	+= $(DRM_PCIIDS_H)
80
81#
82# For now, disable these lint checks; maintainers should endeavor
83# to investigate and remove these for maximum lint coverage.
84# Please do not carry these forward to new Makefiles.
85#
86LINTTAGS	+= -erroff=E_BAD_PTR_CAST_ALIGN
87LINTTAGS	+= -erroff=E_ASSIGN_NARROW_CONV
88LINTTAGS	+= -erroff=E_STATIC_UNUSED
89LINTTAGS	+= -erroff=E_SUSPICIOUS_COMPARISON
90
91#
92#	Default build targets.
93#
94.KEEP_STATE:
95
96def:		$(DEF_DEPS)
97
98all:		$(ALL_DEPS)
99
100clean:		$(CLEAN_DEPS)
101
102clobber:	$(CLOBBER_DEPS)
103
104lint:		$(LINT_DEPS)
105
106modlintlib:	$(MODLINTLIB_DEPS)
107
108clean.lint:	$(CLEAN_LINT_DEPS)
109
110install:	$(INSTALL_DEPS)
111
112$(I915_DRV_O):	$(DRM_PCIIDS_H)
113
114$(I915_DRV_C):	$(DRM_PCIIDS_H)
115
116$(DRM_PCIIDS_H):	$(DRM_PCIIDS_TXT)
117	/bin/sh $(CREATE_SUNOS_PCI_LISTS_SH) $(DRM_PCIIDS_TXT) > $@
118
119#
120#	Include common targets.
121#
122include $(UTSBASE)/intel/Makefile.targ
123