mirror of
https://github.com/python/cpython.git
synced 2024-11-28 20:33:54 +08:00
3fc5d84046
Update the vendored copy of libexpat to 2.4.1 (from 2.2.8) to get the fix for the CVE-2013-0340 "Billion Laughs" vulnerability. This copy is most used on Windows and macOS. Co-authored-by: Łukasz Langa <lukasz@langa.pl>
164 lines
5.7 KiB
C
164 lines
5.7 KiB
C
/* internal.h
|
|
|
|
Internal definitions used by Expat. This is not needed to compile
|
|
client code.
|
|
|
|
The following calling convention macros are defined for frequently
|
|
called functions:
|
|
|
|
FASTCALL - Used for those internal functions that have a simple
|
|
body and a low number of arguments and local variables.
|
|
|
|
PTRCALL - Used for functions called though function pointers.
|
|
|
|
PTRFASTCALL - Like PTRCALL, but for low number of arguments.
|
|
|
|
inline - Used for selected internal functions for which inlining
|
|
may improve performance on some platforms.
|
|
|
|
Note: Use of these macros is based on judgement, not hard rules,
|
|
and therefore subject to change.
|
|
__ __ _
|
|
___\ \/ /_ __ __ _| |_
|
|
/ _ \\ /| '_ \ / _` | __|
|
|
| __// \| |_) | (_| | |_
|
|
\___/_/\_\ .__/ \__,_|\__|
|
|
|_| XML parser
|
|
|
|
Copyright (c) 2002-2003 Fred L. Drake, Jr. <fdrake@users.sourceforge.net>
|
|
Copyright (c) 2002-2006 Karl Waclawek <karl@waclawek.net>
|
|
Copyright (c) 2003 Greg Stein <gstein@users.sourceforge.net>
|
|
Copyright (c) 2016-2021 Sebastian Pipping <sebastian@pipping.org>
|
|
Copyright (c) 2018 Yury Gribov <tetra2005@gmail.com>
|
|
Copyright (c) 2019 David Loffredo <loffredo@steptools.com>
|
|
Licensed under the MIT license:
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining
|
|
a copy of this software and associated documentation files (the
|
|
"Software"), to deal in the Software without restriction, including
|
|
without limitation the rights to use, copy, modify, merge, publish,
|
|
distribute, sublicense, and/or sell copies of the Software, and to permit
|
|
persons to whom the Software is furnished to do so, subject to the
|
|
following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included
|
|
in all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
|
NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#if defined(__GNUC__) && defined(__i386__) && ! defined(__MINGW32__)
|
|
/* We'll use this version by default only where we know it helps.
|
|
|
|
regparm() generates warnings on Solaris boxes. See SF bug #692878.
|
|
|
|
Instability reported with egcs on a RedHat Linux 7.3.
|
|
Let's comment out:
|
|
#define FASTCALL __attribute__((stdcall, regparm(3)))
|
|
and let's try this:
|
|
*/
|
|
# define FASTCALL __attribute__((regparm(3)))
|
|
# define PTRFASTCALL __attribute__((regparm(3)))
|
|
#endif
|
|
|
|
/* Using __fastcall seems to have an unexpected negative effect under
|
|
MS VC++, especially for function pointers, so we won't use it for
|
|
now on that platform. It may be reconsidered for a future release
|
|
if it can be made more effective.
|
|
Likely reason: __fastcall on Windows is like stdcall, therefore
|
|
the compiler cannot perform stack optimizations for call clusters.
|
|
*/
|
|
|
|
/* Make sure all of these are defined if they aren't already. */
|
|
|
|
#ifndef FASTCALL
|
|
# define FASTCALL
|
|
#endif
|
|
|
|
#ifndef PTRCALL
|
|
# define PTRCALL
|
|
#endif
|
|
|
|
#ifndef PTRFASTCALL
|
|
# define PTRFASTCALL
|
|
#endif
|
|
|
|
#ifndef XML_MIN_SIZE
|
|
# if ! defined(__cplusplus) && ! defined(inline)
|
|
# ifdef __GNUC__
|
|
# define inline __inline
|
|
# endif /* __GNUC__ */
|
|
# endif
|
|
#endif /* XML_MIN_SIZE */
|
|
|
|
#ifdef __cplusplus
|
|
# define inline inline
|
|
#else
|
|
# ifndef inline
|
|
# define inline
|
|
# endif
|
|
#endif
|
|
|
|
#include <limits.h> // ULONG_MAX
|
|
|
|
#if defined(_WIN32) && ! defined(__USE_MINGW_ANSI_STDIO)
|
|
# define EXPAT_FMT_ULL(midpart) "%" midpart "I64u"
|
|
# if defined(_WIN64) // Note: modifiers "td" and "zu" do not work for MinGW
|
|
# define EXPAT_FMT_PTRDIFF_T(midpart) "%" midpart "I64d"
|
|
# define EXPAT_FMT_SIZE_T(midpart) "%" midpart "I64u"
|
|
# else
|
|
# define EXPAT_FMT_PTRDIFF_T(midpart) "%" midpart "d"
|
|
# define EXPAT_FMT_SIZE_T(midpart) "%" midpart "u"
|
|
# endif
|
|
#else
|
|
# define EXPAT_FMT_ULL(midpart) "%" midpart "llu"
|
|
# if ! defined(ULONG_MAX)
|
|
# error Compiler did not define ULONG_MAX for us
|
|
# elif ULONG_MAX == 18446744073709551615u // 2^64-1
|
|
# define EXPAT_FMT_PTRDIFF_T(midpart) "%" midpart "ld"
|
|
# define EXPAT_FMT_SIZE_T(midpart) "%" midpart "lu"
|
|
# else
|
|
# define EXPAT_FMT_PTRDIFF_T(midpart) "%" midpart "d"
|
|
# define EXPAT_FMT_SIZE_T(midpart) "%" midpart "u"
|
|
# endif
|
|
#endif
|
|
|
|
#ifndef UNUSED_P
|
|
# define UNUSED_P(p) (void)p
|
|
#endif
|
|
|
|
/* NOTE BEGIN If you ever patch these defaults to greater values
|
|
for non-attack XML payload in your environment,
|
|
please file a bug report with libexpat. Thank you!
|
|
*/
|
|
#define EXPAT_BILLION_LAUGHS_ATTACK_PROTECTION_MAXIMUM_AMPLIFICATION_DEFAULT \
|
|
100.0f
|
|
#define EXPAT_BILLION_LAUGHS_ATTACK_PROTECTION_ACTIVATION_THRESHOLD_DEFAULT \
|
|
8388608 // 8 MiB, 2^23
|
|
/* NOTE END */
|
|
|
|
#include "expat.h" // so we can use type XML_Parser below
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
void _INTERNAL_trim_to_complete_utf8_characters(const char *from,
|
|
const char **fromLimRef);
|
|
|
|
#if defined(XML_DTD)
|
|
unsigned long long testingAccountingGetCountBytesDirect(XML_Parser parser);
|
|
unsigned long long testingAccountingGetCountBytesIndirect(XML_Parser parser);
|
|
const char *unsignedCharToPrintable(unsigned char c);
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|