Sebastian Pipping
571b1bb05e
Merge pull request #955 from libexpat/fix-build-for-oss-fuzz
...
fuzzers|cmake: Disable `xml_lpm_fuzzer` for `-DEXPAT_OSSFUZZ_BUILD=ON`
2025-02-11 15:05:34 +01:00
Sebastian Pipping
392fb29e67
fuzzers|cmake: Disable xml_lpm_fuzzer for -DEXPAT_OSSFUZZ_BUILD=ON
...
.. to give OSS-Fuzz a chance at a successful build while their
images are based on Ubuntu 20.04 with too-old Protobuf
PS: Display this commit with "-w" to see it best.
2025-02-11 14:24:57 +01:00
Sebastian Pipping
c577981ffa
Merge pull request #954 from libexpat/fuzzers-bump-libprotobuf-mutator
...
Fuzzers: Bump libprotobuf-mutator to v1.4-8-g75f1720
2025-02-07 20:31:15 +01:00
Sebastian Pipping
9e906b5bf1
fuzzers|cmake|ci: Save compile time on libprotobuf-mutator examples
...
As a side effect, CI no longer needs to install liblzma-dev.
2025-02-07 19:05:59 +01:00
Sebastian Pipping
14424c70fb
fuzzers|cmake: Bump libprotobuf-mutator to v1.4-8-g75f1720
2025-02-07 19:05:59 +01:00
Sebastian Pipping
78767684c3
fuzzers|cmake: Break up long line (before making it even longer)
2025-02-07 19:05:59 +01:00
Sebastian Pipping
e89e86a90b
Merge pull request #953 from valord577/patch-1
...
Fix warning: no `-Wno-pedantic-ms-format` (`-Wunknown-warning-option`) for LLVM MinGW
2025-02-07 17:17:15 +01:00
valord577
4cb89e6128
fix warning: no -Wno-pedantic-ms-format
for llvm mingw
...
ONLY gcc has `-Wno-pedantic-ms-format`:
https://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html#index-Wno-pedantic-ms-format
2025-02-07 15:51:26 +08:00
Sebastian Pipping
c628ac4d95
Merge pull request #952 from libexpat/fuzzers-stop-linking-against-abseil-explicitly
...
fuzzers|cmake: Stop linking `xml_lpm_fuzzer` against Abseil, explicitly
2025-02-07 00:07:22 +01:00
Sebastian Pipping
3e82dcb383
fuzzers|cmake: Stop linking xml_lpm_fuzzer against Abseil, explicitly
...
This reverts commit d7e41e2de8
but also also adjusts CI.
2025-02-06 23:24:49 +01:00
Sebastian Pipping
079fc26a06
Merge pull request #951 from libexpat/fuzzers-check-for-protobuf-compiler
...
fuzzers|cmake: Check for availability of protobuf compiler
2025-02-03 19:18:59 +01:00
Sebastian Pipping
84ccc3e341
fuzzers|cmake: Check for working protobuf compiler
2025-02-03 18:34:49 +01:00
Sebastian Pipping
caac94df7e
Merge pull request #950 from libexpat/pull-617-finish
...
Add new fuzzer `xml_lpm_fuzzer` (replaces pull request #617 )
2025-02-03 02:59:07 +01:00
Sebastian Pipping
a0b8957db2
Sync file headers
2025-02-03 01:37:51 +01:00
Sebastian Pipping
c18e90f927
xml_lpm_fuzzer: Use common attribution format
2025-02-03 01:36:22 +01:00
Sebastian Pipping
2a615bc3c5
xml_lpm_fuzzer: Unstuck MallocHook and ReallocHook
...
.. so that they fail single allocations, not all
allocations after a certain point. Previously
fail_allocations of [6, 2, 20] worked the same way
fail_allocations of [2], likely by accidently.
2025-02-03 01:23:41 +01:00
Sebastian Pipping
1ed7be5bf7
linux.yml: Drop -DEXPAT_BUILD_FUZZERS=ON case in favor of fuzzing.yml
2025-02-02 22:35:01 +01:00
Sebastian Pipping
57d6e4ad56
fuzzing.yml: Assert xml_lpm_fuzzer executability
...
.. while it is not being using to run any regression tests
2025-02-02 22:34:50 +01:00
Sebastian Pipping
69a7a7090d
fuzzing.yml: Bump to Ubuntu 24.04
...
Due to broken(?) CMake in Ubuntu 22.04, symptom was:
> CMake Error: Error required internal CMake variable not set, cmake may not be built correctly.
> Missing variable is:
> CMAKE_CXX_LINK_EXECUTABLE
> CMake Generate step failed. Build files cannot be regenerated correctly.
2025-02-02 22:19:06 +01:00
Sebastian Pipping
8d7f50bc6e
fuzzing.yml: Pass C++ compiler and compile flags to CMake
2025-02-02 22:19:06 +01:00
Sebastian Pipping
0497f35d04
fuzzing.yml: Install build dependencies of xml_lpm_fuzzer
2025-02-02 22:19:06 +01:00
clang-format 19.1.2
922e95a393
xml_lpm_fuzzer: Apply clang-format 19.1.2
2025-02-02 22:19:06 +01:00
Sebastian Pipping
b223d302cb
xml_lpm_fuzzer: Address warning -Wunused-parameter
2025-02-02 22:19:06 +01:00
Sebastian Pipping
15b1af6716
xml_lpm_fuzzer: Address warning -Wsign-compare
...
Symptom was:
> [..]/expat/fuzz/xml_lpm_fuzzer.cpp:157:25: error: comparison of integers of different signs: 'int' and 'unsigned int' [-Werror,-Wsign-compare]
> 157 | for (int i = 0; i < content->numchildren; ++i) {
> | ~ ^ ~~~~~~~~~~~~~~~~~~~~
> [..]/expat/fuzz/xml_lpm_fuzzer.cpp:183:25: error: comparison of integers of different signs: 'int' and 'unsigned int' [-Werror,-Wsign-compare]
> 183 | for (int i = 0; i < content->numchildren; ++i) {
> | ~ ^ ~~~~~~~~~~~~~~~~~~~~
> [..]/expat/fuzz/xml_lpm_fuzzer.cpp:413:24: error: comparison of integers of different signs: 'size_t' (aka 'unsigned long') and 'int' [-Werror,-Wsign-compare]
> 413 | for (size_t i = 0; i < testcase.fail_allocations_size(); ++i) {
> | ~ ^ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> [..]/expat/fuzz/xml_lpm_fuzzer.cpp:421:24: error: comparison of integers of different signs: 'size_t' (aka 'unsigned long') and 'int' [-Werror,-Wsign-compare]
> 421 | for (size_t i = 0; i < testcase.actions_size(); ++i) {
> | ~ ^ ~~~~~~~~~~~~~~~~~~~~~~~
2025-02-02 22:19:06 +01:00
Sebastian Pipping
48afe247ce
xml_lpm_fuzzer|cmake: Replace -fsanitize=fuzzer-no-link by -fsanitize=fuzzer
...
Same as commit bf9caf7ac4
, different target.
2025-02-02 22:19:06 +01:00
Sebastian Pipping
ea98a87971
xml_lpm_fuzzer: Add trailing newline
2025-02-02 22:19:06 +01:00
Sebastian Pipping
ea492aa54d
xml_lpm_fuzzer: Add missing call to InitializeParser after XML_ParserReset
2025-02-02 22:19:06 +01:00
Sebastian Pipping
6933ee68f1
xml_lpm_fuzzer: Resolve dead code
2025-02-02 22:19:06 +01:00
Sebastian Pipping
d7736d9cfa
xml_lpm_fuzzer: Resolve unused function parameter
2025-02-02 22:19:06 +01:00
Sebastian Pipping
4962f317d2
xml_lpm_fuzzer: Rename function to better match its nature
2025-02-02 22:19:06 +01:00
Sebastian Pipping
e183cb9811
xml_lpm_fuzzer: Be more thorough in model validation
2025-02-02 22:19:06 +01:00
Sebastian Pipping
5f42436e02
xml_lpm_fuzzer: Fix mistaken use of XML_Char
2025-02-02 22:19:06 +01:00
Sebastian Pipping
da8219b9af
xml_lpm_fuzzer: Mark variable "fail_allocations" as global
2025-02-02 22:19:05 +01:00
Sebastian Pipping
2bb8a29428
xml_lpm_fuzzer: Mark variable "allocation_count" as global
2025-02-02 22:19:05 +01:00
Sebastian Pipping
59771b8f7f
xml_lpm_fuzzer: Mark variables external_entity{,_size} as global
2025-02-02 22:19:05 +01:00
Sebastian Pipping
2b73e1bc00
xml_lpm_fuzzer: Mark variable "encoding" as global
...
This resolves variable shadowing in a few places also,
e.g. in XmlDeclHandler and UnknownEncodingHandler.
2025-02-02 22:19:05 +01:00
Sebastian Pipping
2ca8b39167
xml_lpm_fuzzer: Protect assert(...) from NDEBUG
2025-02-02 22:19:05 +01:00
Sebastian Pipping
5551e205d2
fuzzers|cmake: Drop redundant linker language to simplify
...
The other fuzzers need it for EXPAT_OSSFUZZ_BUILD when C becomes C++
but not this one.
2025-02-02 22:19:05 +01:00
Sebastian Pipping
ba8744ae19
fuzzers|cmake: Fix parallel build for xml_lpm_fuzzer
2025-02-02 22:19:05 +01:00
Sebastian Pipping
d7e41e2de8
fuzzers|cmake: Link xml_lpm_fuzzer against Abseil, explicitly
2025-02-02 22:19:05 +01:00
Sebastian Pipping
2fd3844a7c
fuzzers|cmake: Stop compiling libprotobuf-mutator with tests
2025-02-02 22:19:05 +01:00
Sebastian Pipping
c2fd39564c
fuzzers|cmake: Patch default -Werror out of libprotobuf-mutator
...
.. and make it use C++ 17 for recent Abseil
2025-02-02 22:19:05 +01:00
Sebastian Pipping
eedfa51d99
fuzzers|cmake: Downgrade and pin libprotobuf-mutator to v1.1-7-g50ef915
...
On Ubuntu 24.04 the symptom with more recent 1.3 was:
> [ 37%] Building CXX object src/CMakeFiles/protobuf-mutator.dir/text_format.cc.o
> cd /home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator-build/src && /usr/lib/llvm-19/bin/clang++ -I/home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator -I/home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator-build -fno-exceptions -Wno-deprecated-declarations -Wall -Wstring-conversion -std=c++17 -fsanitize-coverage=0 -MD -MT src/CMakeFiles/protobuf-mutator.dir/text_format.cc.o -MF CMakeFiles/protobuf-mutator.dir/text_format.cc.o.d -o CMakeFiles/protobuf-mutator.dir/text_format.cc.o -c /home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator/src/text_format.cc
> In file included from /home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator/src/mutator.cc:27:
> /home/runner/work/libexpat-private/libexpat-private/expat/build/libprotobuf-mutator/src/libprotobuf-mutator/src/field_instance.h:193:50: error: no member named 'requires_utf8_validation' in 'google::protobuf::FieldDescriptor'
> 193 | bool EnforceUtf8() const { return descriptor_->requires_utf8_validation(); }
> | ~~~~~~~~~~~ ^
2025-02-02 22:19:05 +01:00
Sebastian Pipping
d9a91c655d
fuzzers|cmake: Compile as C++17 for recent Abseil
2025-02-02 22:19:05 +01:00
Sebastian Pipping
c87f28da40
fuzzers|cmake: Enable C++ for EXPAT_BUILD_FUZZERS
2025-02-02 22:19:05 +01:00
Sebastian Pipping
b1d40decd9
Revert "fuzzers: Pin tagged versions of protobuf and libprotobuf-mutator"
...
This reverts commit 99314b5d946c0b6851c97714a9b4965284843717.
2025-02-02 22:19:05 +01:00
Sebastian Pipping
8fec1ea699
Merge remote-tracking branch 'c01db33f/fuzzer' into pull-617-finish
2025-02-02 22:17:44 +01:00
Sebastian Pipping
1ddd2ef11d
Merge pull request #947 from libexpat/extend-changelog
...
Extend changelog (i.e. early bits of preparation for release 2.6.5)
2025-01-27 02:05:45 +01:00
Sebastian Pipping
deef285f28
Changes: Promote needs of Python and Perl bindings
2025-01-26 22:24:16 +01:00
Sebastian Pipping
0d0b5a5ae2
Changes: Document changes since release Expat 2.6.4
2025-01-26 22:24:16 +01:00