Merge remote branch 'origin/nv50-compiler'
[mesa.git] / src / gallium / targets / libgl-xlib / Makefile
1 # src/gallium/targets/libgl-xlib/Makefile
2
3 # This makefile produces a "stand-alone" libGL.so which is based on
4 # Xlib (no DRI HW acceleration)
5
6
7 TOP = ../../../..
8 include $(TOP)/configs/current
9
10
11 GL_MAJOR = 1
12 GL_MINOR = 5
13 GL_TINY = 0$(MESA_MAJOR)0$(MESA_MINOR)0$(MESA_TINY)
14
15
16 INCLUDE_DIRS = \
17 -I$(TOP)/include \
18 -I$(TOP)/src/mapi \
19 -I$(TOP)/src/mesa \
20 -I$(TOP)/src/mesa/main \
21 -I$(TOP)/src/gallium/include \
22 -I$(TOP)/src/gallium/drivers \
23 -I$(TOP)/src/gallium/state_trackers/glx/xlib \
24 -I$(TOP)/src/gallium/auxiliary \
25 $(X11_CFLAGS)
26
27 DEFINES += \
28 -DGALLIUM_SOFTPIPE \
29 -DGALLIUM_GALAHAD
30 #-DGALLIUM_CELL will be defined by the config */
31
32 XLIB_TARGET_SOURCES = \
33 xlib.c
34
35
36 XLIB_TARGET_OBJECTS = $(XLIB_TARGET_SOURCES:.c=.o)
37
38
39 # Note: CELL_SPU_LIB is only defined for cell configs
40
41 LIBS = \
42 $(GALLIUM_DRIVERS) \
43 $(TOP)/src/gallium/state_trackers/glx/xlib/libxlib.a \
44 $(TOP)/src/gallium/winsys/sw/xlib/libws_xlib.a \
45 $(TOP)/src/gallium/drivers/trace/libtrace.a \
46 $(TOP)/src/gallium/drivers/rbug/librbug.a \
47 $(TOP)/src/gallium/drivers/identity/libidentity.a \
48 $(TOP)/src/mapi/glapi/libglapi.a \
49 $(TOP)/src/mesa/libmesagallium.a \
50 $(GALLIUM_AUXILIARIES) \
51 $(CELL_SPU_LIB) \
52
53
54 # LLVM
55 ifeq ($(MESA_LLVM),1)
56 DEFINES += -DGALLIUM_LLVMPIPE
57 GL_LIB_DEPS += $(LLVM_LIBS)
58 LDFLAGS += $(LLVM_LDFLAGS)
59 endif
60
61
62 .SUFFIXES : .cpp
63
64 .c.o:
65 $(CC) -c $(INCLUDE_DIRS) $(CFLAGS) $< -o $@
66
67 .cpp.o:
68 $(CXX) -c $(INCLUDE_DIRS) $(CXXFLAGS) $< -o $@
69
70
71
72 default: $(TOP)/$(LIB_DIR)/gallium $(TOP)/$(LIB_DIR)/gallium/$(GL_LIB_NAME)
73
74 $(TOP)/$(LIB_DIR)/gallium:
75 @ mkdir -p $(TOP)/$(LIB_DIR)/gallium
76
77 # Make the libGL.so library
78 $(TOP)/$(LIB_DIR)/gallium/$(GL_LIB_NAME): $(XLIB_TARGET_OBJECTS) $(LIBS) Makefile
79 $(TOP)/bin/mklib -o $(GL_LIB) \
80 -linker "$(CXX)" -ldflags '$(LDFLAGS)' \
81 -major $(GL_MAJOR) -minor $(GL_MINOR) -patch $(GL_TINY) \
82 -cplusplus \
83 -install $(TOP)/$(LIB_DIR)/gallium \
84 $(MKLIB_OPTIONS) $(XLIB_TARGET_OBJECTS) \
85 -Wl,--start-group $(LIBS) -Wl,--end-group $(GL_LIB_DEPS)
86
87
88 depend: $(XLIB_TARGET_SOURCES)
89 @ echo "running $(MKDEP)"
90 @ rm -f depend # workaround oops on gutsy?!?
91 @ touch depend
92 $(MKDEP) $(MKDEP_OPTIONS) $(DEFINES) $(INCLUDE_DIRS) $(XLIB_TARGET_SOURCES) \
93 > /dev/null 2>/dev/null
94
95
96 install: default
97 $(INSTALL) -d $(DESTDIR)$(INSTALL_DIR)/include/GL
98 $(INSTALL) -d $(DESTDIR)$(INSTALL_DIR)/$(LIB_DIR)
99 $(INSTALL) -m 644 $(TOP)/include/GL/*.h $(DESTDIR)$(INSTALL_DIR)/include/GL
100 @if [ -e $(TOP)/$(LIB_DIR)/$(GL_LIB_NAME) ]; then \
101 $(MINSTALL) $(TOP)/$(LIB_DIR)/libGL* $(DESTDIR)$(INSTALL_DIR)/$(LIB_DIR); \
102 fi
103
104
105 # Emacs tags
106 tags:
107 etags `find . -name \*.[ch]` $(TOP)/include/GL/*.h
108
109 clean:
110 -rm -f *.o depend
111
112
113 include depend