Go to file
Jesse Towner dbf9142f7e [sfnt] Fix crash in Load_SBit_Png on Windows x64.
This change fixes a crash that occurs in `Load_SBit_Png` when
running on a 64-bit Windows OS.  A memory access violation exception
would be raised by `setjmp` if the `jmp_buf` is not aligned to a
16-byte memory boundary.  This is due to setjmp executing `movdqa`
instructions to store 128-bit XMM registers to memory, which require
correct memory alignment.  This problem occurs because
`png_create_read_struct` uses `malloc` and `free` for memory
management, which only guarantees 8-byte alignment on Windows.

Instead, to fix the problem, `png_create_read_struct_2` is used on
64-bit Windows, which allows for user-defined memory allocation and
deallocation callbacks to be specified.  These callbacks forward the
allocation and deallocation requests to `_aligned_alloc` and
`_aligned_free`, ensuring that the allocated `png_struct` and
internal `jmp_buf` have the requisite 16-byte alignment.

* src/sfnt/pngshim.c <_WIN64>: Include `malloc.h`.
(malloc_callback, free_callback) <_WIN64>: New functions.
(Load_SBit_Png) <_WIN64>: Use `png_create_read_struct_2` instead of
`png_create_read_struct`
2021-02-27 13:28:13 +01:00
builds * builds/unix/ax_pthread.m4: Update from 'autoconf-archive'. 2021-02-19 20:33:50 +01:00
devel Update all copyright notices. 2021-01-17 07:18:48 +01:00
docs Improve build documentation. 2021-02-27 11:02:53 +01:00
include freetype.h: Documentation typos. 2021-02-27 12:14:02 +01:00
objs * builds/windows/vc2010/freetype.vcxproj: AfterBuild copy. 2017-12-16 22:00:40 -05:00
src [sfnt] Fix crash in Load_SBit_Png on Windows x64. 2021-02-27 13:28:13 +01:00
subprojects Move 'dlg' submodule to subprojects directory. 2021-02-16 14:07:18 +01:00
.clang-format Add .clang-format file 2020-07-16 15:51:06 +02:00
.gitattributes .gitattributes: New file. 2021-01-16 09:13:44 +01:00
.gitignore [builds] Revert `FTMODULE_H' changes. 2021-01-08 13:22:34 -05:00
.gitmodules Move 'dlg' submodule to subprojects directory. 2021-02-16 14:07:18 +01:00
.mailmap .mailmap: Updated and synchronized with 'freetype2-demos' repository. 2020-12-24 08:43:55 +01:00
autogen.sh Move 'dlg' submodule to subprojects directory. 2021-02-16 14:07:18 +01:00
ChangeLog [sfnt] Fix crash in Load_SBit_Png on Windows x64. 2021-02-27 13:28:13 +01:00
CMakeLists.txt * CMakeLists.txt: Update location of LICENSE.TXT. 2021-02-22 15:33:23 +01:00
configure Update all copyright notices. 2021-01-17 07:18:48 +01:00
LICENSE.TXT LICENSE.TXT: Moved to root directory; minor edits. 2021-01-22 09:07:51 +01:00
Makefile Update all copyright notices. 2021-01-17 07:18:48 +01:00
meson_options.txt Meson: Fix dependency lookup and generate ftconfig.h 2021-02-09 16:11:39 +01:00
meson.build * meson.build: s/freetype2_dep/freetype_dep/. 2021-02-10 18:14:47 +01:00
modules.cfg Update all copyright notices. 2021-01-17 07:18:48 +01:00
README Improve build documentation. 2021-02-27 11:02:53 +01:00
README.git Update all copyright notices. 2021-01-17 07:18:48 +01:00
vms_make.com Update all copyright notices. 2021-01-17 07:18:48 +01:00

FreeType 2.10.4
===============

Homepage: https://www.freetype.org

FreeType is a freely available software library to render fonts.

It  is  written  in  C,   designed  to  be  small,  efficient,  highly
customizable,  and portable  while capable  of producing  high-quality
output (glyph images) of most vector and bitmap font formats.

Please   read  the   `docs/CHANGES`   file,   it  contains   IMPORTANT
INFORMATION.

Read the files `docs/INSTALL*`  for installation instructions; see the
file `docs/LICENSE.TXT` for the available licenses.

For using FreeType's git repository  instead of a distribution bundle,
please read file `README.git`.

The FreeType 2 API reference is located in directory `docs/reference`;
use the file  `index.html` as the top entry point.   [Please note that
currently  the search  function  for  locally installed  documentation
doesn't work due to cross-site scripting issues.]

Additional documentation is  available as a separate  package from our
sites.  Go to

  https://download.savannah.gnu.org/releases/freetype/

and download one of the following files.

  freetype-doc-2.10.4.tar.xz
  freetype-doc-2.10.4.tar.gz
  ftdoc2104.zip

To view the documentation online, go to

  https://www.freetype.org/freetype2/docs/


Mailing Lists
-------------

The preferred  way of  communication with the  FreeType team  is using
e-mail lists.

  general use and discussion:      freetype@nongnu.org
  engine internals, porting, etc.: freetype-devel@nongnu.org
  announcements:                   freetype-announce@nongnu.org
  git repository tracker:          freetype-commit@nongnu.org

The lists are moderated; see

  https://www.freetype.org/contact.html

how to subscribe.


Bugs
----

Please submit bug reports at

  https://gitlab.freedesktop.org/freetype/freetype/-/issues

Alternatively,    you    might    report    bugs    by    e-mail    to
`freetype-devel@nongnu.org`.    Don't  forget   to  send   a  detailed
explanation of the problem -- there  is nothing worse than receiving a
terse message that only says 'it doesn't work'.


Patches
-------

For larger changes please provide merge requests at

  https://gitlab.freedesktop.org/freetype/freetype/-/merge_requests

Alternatively, you can send patches to the `freetype-devel@nongnu.org`
mailing list  -- and thank you  in advance for your  work on improving
FreeType!

Details on the process can be found here:

  https://www.freetype.org/developer.html#patches


Enjoy!


  The FreeType Team

----------------------------------------------------------------------

Copyright (C) 2006-2021 by
David Turner, Robert Wilhelm, and Werner Lemberg.

This  file is  part of  the FreeType  project, and  may only  be used,
modified,  and distributed  under the  terms of  the  FreeType project
license,  LICENSE.TXT.  By  continuing to  use, modify,  or distribute
this file you  indicate that you have read  the license and understand
and accept it fully.


--- end of README ---