Add a couple of the missing GL 2.0 functions. Enable GLX protocol for
[mesa.git] / src / mesa / Makefile
index d77af533e1c00c3364ce6f0df5c21d67ca5add50..d4645606f7f6ec38565d88d6b6cced45fa6e1234 100644 (file)
@@ -11,9 +11,14 @@ GL_MINOR = 5
 GL_TINY = 0$(MESA_MAJOR)0$(MESA_MINOR)0$(MESA_TINY)
 
 
+.SUFFIXES : .cpp
+
 .c.o:
        $(CC) -c $(INCLUDE_DIRS) $(CFLAGS) $< -o $@
 
+.cpp.o:
+       $(CXX) -c $(INCLUDE_DIRS) $(CXXFLAGS) $< -o $@
+
 .S.o:
        $(CC) -c $(INCLUDE_DIRS) $(CFLAGS) $< -o $@
 
@@ -26,154 +31,137 @@ default:
                $(MAKE) osmesa-only ; \
        elif [ "$(DRIVER_DIRS)" = "beos" ]; then \
                $(MAKE) beos ; \
+       elif [ "$(DRIVER_DIRS)" = "directfb" ]; then \
+               $(MAKE) directfb ; \
+       elif [ "$(DRIVER_DIRS)" = "fbdev" ]; then \
+               $(MAKE) fbdev ; \
        else \
                $(MAKE) stand-alone ; \
        fi
 
-# BeOS driver target
-beos: depend subdirs mesa.a
-       cd drivers/beos; $(MAKE)
-
 
 ######################################################################
-# Linux solo DRI drivers
+# BeOS driver target
 
-SOLO_C_SOURCES = \
-       $(MAIN_SOURCES)         \
-       $(MATH_SOURCES)         \
-       $(ARRAY_CACHE_SOURCES)  \
-       $(TNL_SOURCES)          \
-       $(SWRAST_SOURCES)       \
-       $(SWRAST_SETUP_SOURCES) \
-       $(SHADER_SOURCES)       \
-       $(ASM_C_SOURCES)        
+beos: depend subdirs libmesa.a
+       cd drivers/beos; $(MAKE)
 
-SOLO_OBJECTS = $(SOLO_C_SOURCES:.c=.o) \
-               $(ASM_SOURCES:.S=.o)
 
-linux-solo: depend subdirs mesa.a drivers-dri
+######################################################################
+# Linux DRI drivers
 
 # Make archive of core object files
-mesa.a:        $(SOLO_OBJECTS)
-       rm -f $@
-       ar rcv $@ $(SOLO_OBJECTS)
-       ranlib $@
+libmesa.a: $(SOLO_OBJECTS)
+       @ $(TOP)/bin/mklib -o mesa -static $(SOLO_OBJECTS);
        @if [ "${CONFIG_NAME}" = "beos" ] ; then \
                mimeset -f "$@" ; \
        fi
 
-# note: cannot use the name of the directory ("drivers") as the
-# target, otherwise make will look & see that the "drivers" directory
-# already exists, so not try to rebuild it...
-drivers-dri:
+linux-solo: depend subdirs libmesa.a
        cd drivers/dri ; $(MAKE)
 
 
+#####################################################################
+# Stand-alone Mesa libGL, no built-in drivers (DirectFB)
+
+libgl-core: $(CORE_OBJECTS)
+       @ $(TOP)/bin/mklib -o $(GL_LIB) -linker '$(CC)' \
+               -major $(MESA_MAJOR) -minor $(MESA_MINOR) -patch $(MESA_TINY) \
+               -install $(TOP)/$(LIB_DIR) $(MKLIB_OPTIONS) $(CORE_OBJECTS) \
+               $(GL_LIB_DEPS)
+
+directfb: depend subdirs libgl-core
+       cd drivers/directfb ; $(MAKE)
+
+
+#####################################################################
+# fbdev Mesa driver (libGL.so)
+
+fbdev: $(CORE_OBJECTS) $(FBDEV_DRIVER_OBJECTS) $(COMMON_DRIVER_OBJECTS)
+       @ $(TOP)/bin/mklib -o $(GL_LIB) -linker '$(CC)' \
+               -major $(MESA_MAJOR) -minor $(MESA_MINOR) -patch $(MESA_TINY) \
+               -install $(TOP)/$(LIB_DIR) $(MKLIB_OPTIONS) \
+               $(CORE_OBJECTS) $(FBDEV_DRIVER_OBJECTS) \
+               $(COMMON_DRIVER_OBJECTS) $(GL_LIB_DEPS)
+
+
 ######################################################################
 # Stand-alone Mesa libGL and libOSMesa
-
 STAND_ALONE_DRIVER_SOURCES = \
        $(COMMON_DRIVER_SOURCES) \
        $(X11_DRIVER_SOURCES) \
        $(GLIDE_DRIVER_SOURCES) \
-       $(SVGA_DRIVER_SOURCES) \
-       $(FBDEV_DRIVER_SOURCES)
-
-STAND_ALONE_SOURCES = \
-       $(CORE_SOURCES) \
-       $(ASM_SOURCES) \
-       $(STAND_ALONE_DRIVER_SOURCES)
-
-# ASM_SOURCES is defined in the config file
-ASM_OBJECTS = $(ASM_SOURCES:.S=.o)
+       $(SVGA_DRIVER_SOURCES)
 
 STAND_ALONE_DRIVER_OBJECTS = $(STAND_ALONE_DRIVER_SOURCES:.c=.o)
 
 STAND_ALONE_OBJECTS = \
        $(CORE_OBJECTS) \
-       $(ASM_OBJECTS) \
        $(STAND_ALONE_DRIVER_OBJECTS)
 
 # For libOSMesa16 or libOSMesa32 we link _all_ the objects into the library,
 # not just the osmesa.o object (i.e. we don't have a libGL).
 OSMESA16_OBJECTS = \
        $(CORE_OBJECTS) \
-       $(ASM_OBJECTS) \
        $(COMMON_DRIVER_OBJECTS) \
        $(OSMESA_DRIVER_OBJECTS)
 
 
-stand-alone: depend subdirs $(LIB_DIR)/$(GL_LIB_NAME) $(LIB_DIR)/$(OSMESA_LIB_NAME)
-
-osmesa-only: depend subdirs $(LIB_DIR)/$(OSMESA_LIB_NAME)
+stand-alone: depend subdirs $(TOP)/$(LIB_DIR)/$(GL_LIB_NAME) $(TOP)/$(LIB_DIR)/$(OSMESA_LIB_NAME)
 
-subdirs:
-       @ (cd x86 ; $(MAKE))
+osmesa-only: depend subdirs $(TOP)/$(LIB_DIR)/$(OSMESA_LIB_NAME)
 
 # Make the GL library
-$(LIB_DIR)/$(GL_LIB_NAME): $(STAND_ALONE_OBJECTS)
-       @ CC=$(CC) CXX=$(CXX) $(TOP)/bin/mklib -o $(GL_LIB) \
+$(TOP)/$(LIB_DIR)/$(GL_LIB_NAME): $(STAND_ALONE_OBJECTS)
+       @ $(TOP)/bin/mklib -o $(GL_LIB) -linker '$(CC)' \
                -major $(GL_MAJOR) -minor $(GL_MINOR) -patch $(GL_TINY) \
-               -install $(LIB_DIR) \
+               -install $(TOP)/$(LIB_DIR) \
                $(MKLIB_OPTIONS) $(GL_LIB_DEPS) $(STAND_ALONE_OBJECTS)
 
 # Make the OSMesa library
-$(LIB_DIR)/$(OSMESA_LIB_NAME): $(OSMESA_DRIVER_OBJECTS) $(OSMESA16_OBJECTS)
+$(TOP)/$(LIB_DIR)/$(OSMESA_LIB_NAME): $(OSMESA_DRIVER_OBJECTS) $(OSMESA16_OBJECTS)
        @ if [ "${DRIVER_DIRS}" = "osmesa" ] ; then \
-               CC=$(CC) CXX=$(CXX) $(TOP)/bin/mklib -o $(OSMESA_LIB) \
+               $(TOP)/bin/mklib -o $(OSMESA_LIB) -linker '$(CC)' \
                        -major $(MESA_MAJOR) \
                        -minor $(MESA_MINOR) -patch $(MESA_TINY) \
-                       -install $(LIB_DIR) $(MKLIB_OPTIONS) \
+                       -install $(TOP)/$(LIB_DIR) $(MKLIB_OPTIONS) \
                        $(OSMESA_LIB_DEPS) $(OSMESA16_OBJECTS) ; \
        else \
-               CC=$(CC) CXX=$(CXX) $(TOP)/bin/mklib -o $(OSMESA_LIB) \
+               $(TOP)/bin/mklib -o $(OSMESA_LIB) -linker '$(CC)' \
                        -major $(MESA_MAJOR) \
                        -minor $(MESA_MINOR) -patch $(GL_TINY) \
-                       -install $(LIB_DIR) $(MKLIB_OPTIONS) \
+                       -install $(TOP)/$(LIB_DIR) $(MKLIB_OPTIONS) \
                        $(OSMESA_LIB_DEPS) $(OSMESA_DRIVER_OBJECTS) ; \
        fi
 
 
-######################################################################
-# 16 (or 32) bit/channel OSMesa
-
-# $(LIB_DIR)/$(OSMESA_LIB_NAME): $(OSMESA16_OBJECTS)
-#      $(TOP)/bin/mklib -o $(OSMESA_LIB) \
-#              -major $(MESA_MAJOR) -minor $(MESA_MINOR) -patch $(MESA_TINY) \
-#              -install $(LIB_DIR) \
-#              $(MKLIB_OPTIONS) $(GL_LIB_DEPS) $(OSMESA16_OBJECTS)
-
-
-
 ######################################################################
 # Generic stuff
 
-ALL_SOURCES = \
-       $(GLAPI_SOURCES)        \
-       $(MAIN_SOURCES)         \
-       $(MATH_SOURCES)         \
-       $(ARRAY_CACHE_SOURCES)  \
-       $(TNL_SOURCES)          \
-       $(SHADER_SOURCES)       \
-       $(SWRAST_SOURCES)       \
-       $(SWRAST_SETUP_SOURCES) \
-       $(ASM_C_SOURCES)        \
-       $(X86_SOURCES)          \
-       $(COMMON_DRIVER_SOURCES)\
-       $(X11_DRIVER_SOURCES)   \
-       $(OSMESA_DRIVER_SOURCES)
+depend: $(ALL_SOURCES)
+       @ echo "running $(MKDEP)"
+       @ touch depend
+       $(MKDEP) $(MKDEP_OPTIONS) $(DEFINES) $(INCLUDE_DIRS) $(ALL_SOURCES) \
+               > /dev/null 
 
 
-SUBDIRS = array_cache drivers/dri glapi main math sparc swrast swrast_setup \
-       tnl tnl_dd
+subdirs:
+       @ (cd x86 ; $(MAKE))
+       @ (cd x86-64 ; $(MAKE))
 
 
-# Update dependencies
-depend: $(ALL_SOURCES)
-       @ echo "running $(MKDEP)"
-       @ touch depend
-       @ $(MKDEP) $(MKDEP_OPTIONS) $(INCLUDE_DIRS) $(ALL_SOURCES) \
-               > /dev/null 2>&1
+install: default
+       $(INSTALL) -d $(INSTALL_DIR)/include/GL
+       $(INSTALL) -d $(INSTALL_DIR)/$(LIB_DIR)
+       $(INSTALL) -m 644 $(TOP)/include/GL/*.h $(INSTALL_DIR)/include/GL
+       $(COPY_LIBS) $(TOP)/$(LIB_DIR)/libGL.* $(INSTALL_DIR)/$(LIB_DIR)
+       @if [ "${DRIVER_DIRS}" = "dri" ] ; then \
+               cd drivers/dri ; $(MAKE) install ; \
+       fi
+
+       ## NOT YET:
+       ## $(INSTALL) -d $(INSTALL_DIR)/include/GLES
+       ## $(INSTALL) -m 644 include/GLES/*.h $(INSTALL_DIR)/include/GLES
 
 
 # Emacs tags
@@ -182,8 +170,12 @@ tags:
 
 clean:
        -rm -f */*.o
-       -rm -f depend depend.bak mesa.a
+       -rm -f */*/*.o
+       -rm -f depend depend.bak libmesa.a
        -rm -f drivers/*/*.o
        (cd drivers/dri ; $(MAKE) clean)
+       (cd x86 ; $(MAKE) clean)
+       (cd x86-64 ; $(MAKE) clean)
+
 
 include depend