>> Subject: xfree86-4 crash: cannot load module xtt >> From: Takashi Ogihara <[EMAIL PROTECTED]> >> To: <[EMAIL PROTECTED]> Message-ID: <[EMAIL PROTECTED]> >Mime-version: 1.0 >> >> Package: xserver-xfree86 >> Version: 4.0.1-8 >> >> when I started X with module "xtt", xserver crashes. >> >> following are console messages: >> >> Symbol TT_Realloc from module /usr/X11R6/lib/modules/fonts/libxtt.a is >> unresolved! >> Symbol TT_Register_Extention from module >> /usr/X11R6/lib/modules/fonts/libxtt.a is unresolved! >> Symbol Extention_Get from module /usr/X11R6/lib/modules/fonts/libxtt.a is >> unresolved! This is an upstream bug. X-TrueType refereed ft_config.h in xc/lib/font/FreeType. ft_config.h is used for FreeType library (not freetype engine of libfont) setting. Both X-TT and freefype engine used same setting previously, but when freetype was updated to 1.1.8, freetype engine would not use some functions included in FreeType library, so changed to undefine TT_CONFIG_OPTION_EXTEND_ENGINE in ft_config.h. But these functions are still needed for X-TT, so when compile X-TrueType engine, we need to define TT_CONFIG_OPTION_EXTEND_ENGINE. I've tried to add -DTT_CONFIG_OPTION_EXTEND_ENGINE in xc/lib/font/X_TrueType/Imakefile and xc/lib/font/X_TrueType/modules/Imakefile simply. But this solution did not work. Because when `#include "ft_config.h"' this file includes "#undef TT_CONFIG_OPTION_EXTEND_ENGINE" line, so TT_CONFIG_OPTION_EXTEND_ENGINE would be undefined in a source. This is a patch to fix this problem. 1) Add newfile xc/lib/font/X-TrueType/ft_config.h for X-TrueType specific setting of FreeType library. 2) not to refer freetype engine's directory (xc/lib/font/FreeType). diff -x Makefile -crN xc.orig/lib/font/X-TrueType/Imakefile xc/lib/font/X-TrueType/Imakefile *** xc.orig/lib/font/X-TrueType/Imakefile Tue Nov 28 04:18:35 2000 --- xc/lib/font/X-TrueType/Imakefile Tue Nov 28 04:02:10 2000 *************** *** 11,17 **** INCLUDES = -I. -I$(FONTINCSRC) -I../include -I../fontcache \ -I$(XTOP)/include -I$(SERVERSRC)/include \ -I$(FTSOURCEDIR)/lib -I$(FTSOURCEDIR)/lib/extend \ ! -I$(FTSOURCEDIR)/lib/arch/unix -I$(FONTLIBSRC)/FreeType DEFINES = -DTT_MAKE_OPTION_SINGLE_OBJECT=1 $(FONTMODULEDEF) \ $(XTT_DEBUG_FLAGS) $(XTT_CCONV_MOUDLE_DEFINES) \ --- 11,17 ---- INCLUDES = -I. -I$(FONTINCSRC) -I../include -I../fontcache \ -I$(XTOP)/include -I$(SERVERSRC)/include \ -I$(FTSOURCEDIR)/lib -I$(FTSOURCEDIR)/lib/extend \ ! -I$(FTSOURCEDIR)/lib/arch/unix DEFINES = -DTT_MAKE_OPTION_SINGLE_OBJECT=1 $(FONTMODULEDEF) \ $(XTT_DEBUG_FLAGS) $(XTT_CCONV_MOUDLE_DEFINES) \ diff -x Makefile -crN xc.orig/lib/font/X-TrueType/ft_conf.h xc/lib/font/X-TrueType/ft_conf.h *** xc.orig/lib/font/X-TrueType/ft_conf.h Thu Jan 1 09:00:00 1970 --- xc/lib/font/X-TrueType/ft_conf.h Tue Nov 28 04:20:48 2000 *************** *** 0 **** --- 1,185 ---- + /* ft_conf.h. Xserver-specific version for X-TrueType. */ + + /* $XFree86: xc/lib/font/X-TreeType/ft_conf.h,v 1.0 2000/11/28 16:54:42 dawes Exp $ +*/ + + /* we need the following because there are some typedefs in this file */ + #ifndef FT_CONF_H + #define FT_CONF_H + + #include <X11/Xmd.h> + #include "servermd.h" + #include "fontmisc.h" + #include <X11/Xfuncproto.h> + + #ifndef FONTMODULE + + #include <X11/Xos.h> + #include <string.h> + #include <stdio.h> + #ifdef _XOPEN_SOURCE + #include <math.h> + #else + #define _XOPEN_SOURCE /* to get prototype for hypot on some systems */ + #include <math.h> + #undef _XOPEN_SOURCE + #endif + /* Define if you have the <stdlib.h> header file. */ + #ifndef X_NOT_STDC_ENV + #define HAVE_STDLIB_H 1 + #endif + + #else + + #include "xf86_ansic.h" + + #endif /* FONTMODULE */ + + /* Define to empty if the keyword does not work. */ + #define const _Xconst /* defined in Xfuncproto.h */ + + /* Define if you have a working `mmap' system call. */ + /* Defined in Makefile */ + /* #undef HAVE_MMAP */ + + /* Define if your processor stores words with the most significant + byte first (like Motorola and SPARC, unlike Intel and VAX). */ + /* defined in servermd.h */ + #if(IMAGE_BYTE_ORDER==MSBFirst) + #define WORDS_BIGENDIAN 1 + #else + #define WORDS_BIGENDIAN 0 + #endif + + + /* Define if the X Window System is missing or not being used. */ + /* Not relevant. */ + /* #undef X_DISPLAY_MISSING */ + + /* Define if you have the getpagesize function. */ + #ifdef HAVE_MMAP + #define HAVE_GETPAGESIZE 1 + #endif + + /* Define if you have the memcpy function. */ + #define HAVE_MEMCPY 1 /* provided by Xos.h */ + + /* Define if you have the memmove function. */ + #define HAVE_MEMMOVE 1 /* provided by Xos.h */ + + /* Define if you have the <fcntl.h> header file. */ + #undef HAVE_FCNTL_H /* included by Xos.h if relevant*/ + + /* Define if you have the <unistd.h> header file. */ + #undef HAVE_UNISTD_H /* included by Xos.h if relevant */ + + /* Define if you have the <locale.h> header file. */ + /* Not relevant */ + /* #undef HAVE_LOCALE_H */ + + /* Define if you have the <libintl.h> header file. */ + /* Not relevant */ + /* #undef HAVE_LIBINTL_H */ + + /* Define if you have the libintl library. */ + /* Not relevant */ + /* #undef HAVE_LIBINTL */ + + /**********************************************************************/ + /* */ + /* The following configuration macros can be tweaked manually by */ + /* a developer to turn on or off certain features or options in the */ + /* TrueType engine. This may be useful to tune it for specific */ + /* purposes.. */ + /* */ + /**********************************************************************/ + + /*************************************************************************/ + /* Define this if the underlying operating system uses a different */ + /* character width than 8bit for file names. You must then also supply */ + /* a typedef declaration for defining 'TT_Text'. Default is off. */ + + /* #undef HAVE_TT_TEXT */ + + + /*************************************************************************/ + /* Define this if you want to generate code to support engine extensions */ + /* Default is on, but if you're satisfied by the basic services provided */ + /* by the engine and need no extensions, undefine this configuration */ + /* macro to save a few more bytes. */ + + #define TT_CONFIG_OPTION_EXTEND_ENGINE + + + /*************************************************************************/ + /* Define this if you want to generate code to support gray-scaling, */ + /* a.k.a. font-smoothing or anti-aliasing. Default is on, but you can */ + /* disable it if you don't need it. */ + + #undef TT_CONFIG_OPTION_GRAY_SCALING + + /*************************************************************************/ + /* Define this if you want to use a big 'switch' statement within the */ + /* bytecode interpreter. Because some non-optimizing compilers are not */ + /* able to produce jump tables from such statements, undefining this */ + /* configuration macro will generate the appropriate C jump table in */ + /* ttinterp.c. If you use an optimizing compiler, you should leave it */ + /* defined for better performance and code compactness.. */ + + #define TT_CONFIG_OPTION_INTERPRETER_SWITCH + + + /*************************************************************************/ + /* Define TT_CONFIG_THREAD_SAFE if you want to build a thread-safe */ + /* version of the library. */ + + /* #undef TT_CONFIG_OPTION_THREAD_SAFE */ + + /**********************************************************************/ + /* */ + /* The following macros are used to define the debug level, as well */ + /* as individual tracing levels for each component. There are */ + /* currently three modes of operation : */ + /* */ + /* - trace mode (define DEBUG_LEVEL_TRACE) */ + /* */ + /* The engine prints all error messages, as well as tracing */ + /* ones, filtered by each component's level */ + /* */ + /* - debug mode (define DEBUG_LEVEL_ERROR) */ + /* */ + /* Disable tracing, but keeps error output and assertion */ + /* checks. */ + /* */ + /* - release mode (don't define anything) */ + /* */ + /* Don't include error-checking or tracing code in the */ + /* engine's code. Ideal for releases. */ + /* */ + /* NOTE : */ + /* */ + /* Each component's tracing level is defined in its own source. */ + /* */ + /**********************************************************************/ + + /* Define if you want to use the tracing debug mode */ + /* #undef DEBUG_LEVEL_TRACE */ + + /* Define if you want to use the error debug mode - ignored if */ + /* DEBUG_LEVEL_TRACE is defined */ + /* #undef DEBUG_LEVEL_ERROR */ + + /**************************************************************************/ + /* Definition of various integer sizes. These types are used by ttcalc */ + /* and ttinterp (for the 64-bit integers) only.. */ + + /* Use X-specific configuration methods */ + + typedef INT32 TT_Int32; + typedef CARD32 TT_Word32; + + #if defined(WORD64) || defined(_XSERVER64) + #define LONG64 + #define INT64 long + #endif /* WORD64 */ + + #endif /* FT_CONF_H */ diff -x Makefile -crN xc.orig/lib/font/X-TrueType/module/Imakefile xc/lib/font/X-TrueType/module/Imakefile *** xc.orig/lib/font/X-TrueType/module/Imakefile Tue Nov 28 04:18:35 2000 --- xc/lib/font/X-TrueType/module/Imakefile Tue Nov 28 04:01:40 2000 *************** *** 14,20 **** INCLUDES = -I.. -I$(FONTINCSRC) -I../../include -I../../fontcache \ -I$(TOP)/include -I$(SERVERSRC)/include \ -I$(FTSOURCEDIR)/lib -I$(FTSOURCEDIR)/lib/extend \ ! -I$(FTSOURCEDIR)/lib/arch/unix -I$(FONTLIBSRC)/FreeType #if XTrueTypeDebugXTT XTT_DEBUG_FLAGS = -DDUMP --- 14,20 ---- INCLUDES = -I.. -I$(FONTINCSRC) -I../../include -I../../fontcache \ -I$(TOP)/include -I$(SERVERSRC)/include \ -I$(FTSOURCEDIR)/lib -I$(FTSOURCEDIR)/lib/extend \ ! -I$(FTSOURCEDIR)/lib/arch/unix #if XTrueTypeDebugXTT XTT_DEBUG_FLAGS = -DDUMP -- ISHIKAWA Mutsumi <[EMAIL PROTECTED]>, <[EMAIL PROTECTED]>, <[EMAIL PROTECTED]> -- To UNSUBSCRIBE, email to [EMAIL PROTECTED] with a subject of "unsubscribe". Trouble? Contact [EMAIL PROTECTED]