[poppler] Can't open files bigger than 2 GB on linux with cmake-generated config.h
Fabio D'Urso
fabiodurso at hotmail.it
Wed May 22 11:56:07 PDT 2013
On Wednesday, May 22, 2013 12:54:44 PM Fabio D'Urso wrote:
> On Tuesday, May 21, 2013 03:23:02 PM Albert Astals Cid wrote:
> > El Divendres, 26 d'abril de 2013, a les 01:24:41, Fabio D'Urso va
escriure:
> > > Hi,
> >
> > Hi
> >
> > > I compile poppler via CMake and, if I try to open a large file (>2 GB)
> > > on
> > > my>
> > >
> > > 32-bit linux system, I get the following error:
> > > Error: Couldn't open file 'big.pdf': Value too large for defined data
> > > type.
> > >
> > > Turns out that open() refuses to open large files unless
> > >
> > > #define _FILE_OFFSET_BITS 64
> > >
> > > is defined.
> > >
> > > So I've checked how config.h is generated and I noticed that only
> > > autotool's config.h.in defines _FILE_OFFSET_BITS.
> > >
> > > CMake's config.h.cmake has this and a few similar macros commented out:
> > > /* Number of bits in a file offset, on hosts where this is settable. */
> > > /* #undef _FILE_OFFSET_BITS */
> > >
> > > /* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2).
> > > */
> > > /* #undef _LARGEFILE_SOURCE */
> > >
> > > /* Define for large files, on AIX-style hosts. */
> > > /* #undef _LARGE_FILES */
> > >
> > > On my system, manually setting #define _FILE_OFFSET_BITS 64
> > > in the generated config.h file is enough to make LFS work.
> > >
> > > Unfortunately, cmake stuff is out of my comfort zone, so I can't write a
> > > proper patch myself :(
> >
> > Can you try the following patch and tell me if it helps?
>
> Works for me, but I also had to change this:
>
> diff --git a/config.h.cmake b/config.h.cmake
> index c3b30db..a8a0c46 100644
> --- a/config.h.cmake
> +++ b/config.h.cmake
> @@ -222,7 +222,7 @@
> #endif
>
> /* Number of bits in a file offset, on hosts where this is settable. */
> -/* #undef _FILE_OFFSET_BITS */
> +#cmakedefine _FILE_OFFSET_BITS @_FILE_OFFSET_BITS@
>
> /* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
> /* #undef _LARGEFILE_SOURCE */
>
> Tested on my laptop (Linux/x86 32 bit).
> I'll test on MacOS/ppc64 when I get back home.
It works there too (=it successfully detects that, unlike on Linux/x86 32-bit,
there's no need to define _FILE_OFFSET_BITS and therefore doesn't define it).
> > Cheers,
> >
> > Albert
> >
> > > Fabio
> > >
> > > _______________________________________________
> > > poppler mailing list
> > > poppler at lists.freedesktop.org
> > > http://lists.freedesktop.org/mailman/listinfo/poppler
--
Fabio
More information about the poppler
mailing list