[ https://issues.apache.org/jira/browse/XERCESC-1809?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12606277#action_12606277 ]
Guido Jäkel commented on XERCESC-1809: -------------------------------------- Dear Boris, for completeness, i let build the Xerces-C samples, too. As expected, now they are roughly running. To compare with the above, here the current strace of SAX2Count. Guido ------------ [EMAIL PROTECTED] /var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data # ../../bin/SAX2Count personal.xml personal.xml: 1 ms (37 elems, 12 attrs, 134 spaces, 134 chars) [EMAIL PROTECTED] /var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data # strace ../../bin/SAX2Count personal.xml execve("../../bin/SAX2Count", ["../../bin/SAX2Count", "personal.xml"], [/* 36 vars */]) = 0 brk(0) = 0x60a000 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e203f000 uname({sys="Linux", node="leo2", ...}) = 0 access("/etc/ld.so.preload", R_OK) = -1 ENOENT (No such file or directory) open("/etc/ld.so.cache", O_RDONLY) = 3 fstat(3, {st_mode=S_IFREG|0644, st_size=24304, ...}) = 0 mmap(NULL, 24304, PROT_READ, MAP_PRIVATE, 3, 0) = 0x2ad4e2040000 close(3) = 0 open("/usr/lib/libxerces-c.so.28", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0`t\30\0\0\0\0\0"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0755, st_size=4389840, ...}) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2046000 mmap(NULL, 6488504, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e2240000 mprotect(0x2ad4e262c000, 2093056, PROT_NONE) = 0 mmap(0x2ad4e282b000, 282624, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x3eb000) = 0x2ad4e282b000 mmap(0x2ad4e2870000, 440, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2870000 close(3) = 0 open("/lib/libpthread.so.0", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\260W\0\0\0\0\0\0"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0755, st_size=131577, ...}) = 0 mmap(NULL, 2204528, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e2871000 mprotect(0x2ad4e2886000, 2097152, PROT_NONE) = 0 mmap(0x2ad4e2a86000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x15000) = 0x2ad4e2a86000 mmap(0x2ad4e2a88000, 13168, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2a88000 close(3) = 0 open("/usr/lib/gcc/x86_64-pc-linux-gnu/4.1.2/libstdc++.so.6", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>[EMAIL PROTECTED]"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0755, st_size=985888, ...}) = 0 mmap(NULL, 3157792, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e2a8c000 mprotect(0x2ad4e2b74000, 2097152, PROT_NONE) = 0 mmap(0x2ad4e2d74000, 36864, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0xe8000) = 0x2ad4e2d74000 mmap(0x2ad4e2d7d000, 73504, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2d7d000 close(3) = 0 open("/lib/libm.so.6", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\0?\0\0\0\0\0\0"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0755, st_size=526472, ...}) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2d8f000 mmap(NULL, 2621672, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e2d90000 mprotect(0x2ad4e2e10000, 2093056, PROT_NONE) = 0 mmap(0x2ad4e300f000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x7f000) = 0x2ad4e300f000 close(3) = 0 open("/lib/libgcc_s.so.1", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\360\37\0\0\0\0\0\0"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0644, st_size=55400, ...}) = 0 mmap(NULL, 2151240, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e3011000 mprotect(0x2ad4e301e000, 2093056, PROT_NONE) = 0 mmap(0x2ad4e321d000, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0xc000) = 0x2ad4e321d000 close(3) = 0 open("/lib/libc.so.6", O_RDONLY) = 3 read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\220\334\1\0\0\0\0\0"..., 832) = 832 fstat(3, {st_mode=S_IFREG|0755, st_size=1293456, ...}) = 0 mmap(NULL, 3399928, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x2ad4e321f000 mprotect(0x2ad4e3355000, 2093056, PROT_NONE) = 0 mmap(0x2ad4e3554000, 20480, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x135000) = 0x2ad4e3554000 mmap(0x2ad4e3559000, 16632, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x2ad4e3559000 close(3) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e355e000 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e355f000 arch_prctl(ARCH_SET_FS, 0x2ad4e355f2f0) = 0 mprotect(0x2ad4e3554000, 16384, PROT_READ) = 0 mprotect(0x2ad4e321d000, 4096, PROT_READ) = 0 mprotect(0x2ad4e300f000, 4096, PROT_READ) = 0 mprotect(0x2ad4e2d74000, 28672, PROT_READ) = 0 mprotect(0x2ad4e2a86000, 4096, PROT_READ) = 0 mprotect(0x2ad4e282b000, 110592, PROT_READ) = 0 mprotect(0x608000, 4096, PROT_READ) = 0 mprotect(0x2ad4e223e000, 4096, PROT_READ) = 0 munmap(0x2ad4e2040000, 24304) = 0 set_tid_address(0x2ad4e355f380) = 15026 set_robust_list(0x2ad4e355f390, 0x18) = 0 rt_sigaction(SIGRTMIN, {0x2ad4e2876320, [], SA_RESTORER|SA_SIGINFO, 0x2ad4e287eed0}, NULL, 8) = 0 rt_sigaction(SIGRT_1, {0x2ad4e28763a0, [], SA_RESTORER|SA_RESTART|SA_SIGINFO, 0x2ad4e287eed0}, NULL, 8) = 0 rt_sigprocmask(SIG_UNBLOCK, [RTMIN RT_1], NULL, 8) = 0 getrlimit(RLIMIT_STACK, {rlim_cur=8192*1024, rlim_max=RLIM_INFINITY}) = 0 futex(0x2ad4e2d7ec88, FUTEX_WAKE, 2147483647) = 0 brk(0) = 0x60a000 brk(0x62b000) = 0x62b000 getcwd("/var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data", 4097) = 78 open("/var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data/personal.xml", O_RDONLY) = 3 mmap(NULL, 167936, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2047000 fstat(3, {st_mode=S_IFREG|0644, st_size=1172, ...}) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2070000 read(3, "<?xml version=\"1.0\" encoding=\"is"..., 49152) = 1172 read(3, "", 45056) = 0 open("/var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data/personal.dtd", O_RDONLY) = 4 mmap(NULL, 167936, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2071000 fstat(4, {st_mode=S_IFREG|0644, st_size=433, ...}) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e209a000 read(4, "<?xml encoding=\"ISO-8859-1\"?>\n\n<"..., 49152) = 433 read(4, "", 45056) = 0 read(4, "", 49152) = 0 close(4) = 0 munmap(0x2ad4e209a000, 4096) = 0 munmap(0x2ad4e2071000, 167936) = 0 futex(0x2ad4e321e130, FUTEX_WAKE, 2147483647) = 0 read(3, "", 49152) = 0 close(3) = 0 munmap(0x2ad4e2070000, 4096) = 0 munmap(0x2ad4e2047000, 167936) = 0 fstat(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 0), ...}) = 0 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2ad4e2047000 write(1, "personal.xml: 2 ms (37 elems, 12"..., 63personal.xml: 2 ms (37 elems, 12 attrs, 134 spaces, 134 chars) ) = 63 exit_group(0) = ? [EMAIL PROTECTED] /var/tmp/portage/dev-libs/xerces-c-2.8.0/work/xerces-c-src_2_8_0/samples/data # > seg fault on 64bit > ------------------ > > Key: XERCESC-1809 > URL: https://issues.apache.org/jira/browse/XERCESC-1809 > Project: Xerces-C++ > Issue Type: Bug > Affects Versions: 2.8.0 > Environment: Gentoo-Linux (emerge --version -> Portage 2.1.4.4 > (default-linux/amd64/2007.0, gcc-4.1.2, glibc-2.6.1-r0, 2.6.21-gentoo-r4 > x86_64)) > Reporter: Guido Jäkel > > I try to advance the Gentoo ebuild for dbxml to 2.4.13. For that, Xerces-C > 2.8.0 and XQuilla is a prerequesite. The Gentoo ebuild for Xerces-C have been > tweeked to include the patches for XQilla this days. Now i'm able to build > dbxml on 32bit and 64bit. On 32bit it seems to work from the first tests, but > on 64bit even a simple "dbxml -v" dies with an segmentation fault. > With gdb, i got the following stack trace: > #0 0x00002abcb1fe6c2c in ?? () from /lib/libc.so.6 > #1 0x00002abcb14f5de0 in xercesc_2_8::XMLString::parseInt () from > /usr/lib/libxerces-c.so.28 > #2 0x00002abcb13b3bbd in xercesc_2_8::AbstractStringValidator::assignFacet () > from /usr/lib/libxerces-c.so.28 > #3 0x00002abcb13b411d in xercesc_2_8::AbstractStringValidator::init () from > /usr/lib/libxerces-c.so.28 > #4 0x00002abcb144cfe0 in > xercesc_2_8::ListDatatypeValidator::ListDatatypeValidator () from > /usr/lib/libxerces-c.so.28 > #5 0x00002abcb141837e in > xercesc_2_8::DatatypeValidatorFactory::createDatatypeValidator () from > /usr/lib/libxerces-c.so.28 > #6 0x00002abcb14198f9 in > xercesc_2_8::DatatypeValidatorFactory::expandRegistryToFullSchemaSet () > from /usr/lib/libxerces-c.so.28 > #7 0x00002abcb097e733 in XQillaPlatformUtils::initialize () from > /usr/lib/libxqilla.so.4 > #8 0x00002abcb00d9fff in DbXml::Globals::initializeXmlPlatform () from > /usr/lib/libdbxml-2.4.so > #9 0x00002abcb00da53f in DbXml::Globals::initialize () from > /usr/lib/libdbxml-2.4.so > #10 0x00002abcb00df043 in DbXml::Manager::Manager () from > /usr/lib/libdbxml-2.4.so > #11 0x00002abcb00d8fca in DbXml::XmlManager::XmlManager () from > /usr/lib/libdbxml-2.4.so > #12 0x000000000040c259 in ?? () > #13 0x00002abcb1fd0b74 in __libc_start_main () from /lib/libc.so.6 > #14 0x000000000040ba39 in ?? () > #15 0x00007ffffad47148 in ?? () > #16 0x0000000000000000 in ?? () > From that, i *guess* that it break's HERE, because this looks like a > libc-call to me. > .../xerces-c-src/src/xercesc/util/XMLString.cpp: > int XMLString::parseInt(const XMLCh* const toConvert > , MemoryManager* const manager) > { > // If no string, or empty string, then it is a failure > if ((!toConvert) || (!*toConvert)) > ThrowXMLwithMemMgr(NumberFormatException, > XMLExcepts::XMLNUM_null_ptr, manager); > XMLCh* trimmedStr = XMLString::replicate(toConvert, manager); > ArrayJanitor<XMLCh> jan1(trimmedStr, manager); > XMLString::trim(trimmedStr); > unsigned int trimmedStrLen = XMLString::stringLen(trimmedStr); > if ( !trimmedStrLen ) > ThrowXMLwithMemMgr(NumberFormatException, > XMLExcepts::XMLNUM_null_ptr, manager); > //the errno set by previous run is NOT automatically cleared > errno = 0; > char *nptr = XMLString::transcode(trimmedStr, manager); > ArrayJanitor<char> jan2(nptr, manager); > char *endptr; > long retVal = strtol(nptr, &endptr, 10); <-----[HERE] > // check if all chars are valid char > if ( (endptr - nptr) != (int) trimmedStrLen) > ThrowXMLwithMemMgr(NumberFormatException, > XMLExcepts::XMLNUM_Inv_chars, manager); > // check if overflow/underflow occurs > if (errno == ERANGE) > ThrowXMLwithMemMgr(NumberFormatException, > XMLExcepts::Str_ConvertOverflow, manager); > // > // REVISIT: conversion of (long) to (int) > // may truncate value on IA64 > return (int) retVal; > } > May please anybody give me a hint how to get it running on 64bit? Feel free > to ask for further information you'll need, > thank you > Guido -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online. --------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]