public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: "Peter Müller" <peter.mueller@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] libjpeg: Update to version 2.1.4
Date: Tue, 27 Dec 2022 16:12:50 +0000	[thread overview]
Message-ID: <0b6d94c6-ae7d-18d3-1cca-410f81c997ee@ipfire.org> (raw)
In-Reply-To: <20221227120002.12161-11-adolf.belka@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 21091 bytes --]

Reviewed-by: Peter Müller <peter.mueller(a)ipfire.org>

> - Update from version 2.0.4 to 2.1.4
> - Update of rootfile
> - Changelog
>     2.1.4
> 	### Significant changes relative to 2.1.3
> 	1. Fixed a regression introduced in 2.1.3 that caused build failures with
> 	Visual Studio 2010.
> 	2. The `tjDecompressHeader3()` function in the TurboJPEG C API and the
> 	`TJDecompressor.setSourceImage()` method in the TurboJPEG Java API now accept
> 	"abbreviated table specification" (AKA "tables-only") datastreams, which can be
> 	used to prime the decompressor with quantization and Huffman tables that can be
> 	used when decompressing subsequent "abbreviated image" datastreams.
> 	3. libjpeg-turbo now performs run-time detection of AltiVec instructions on
> 	OS X/PowerPC systems if AltiVec instructions are not enabled at compile time.
> 	This allows both AltiVec-equipped (PowerPC G4 and G5) and non-AltiVec-equipped
> 	(PowerPC G3) CPUs to be supported using the same build of libjpeg-turbo.
> 	4. Fixed an error ("Bogus virtual array access") that occurred when attempting
> 	to decompress a progressive JPEG image with a height less than or equal to one
> 	iMCU (8 * the vertical sampling factor) using buffered-image mode with
> 	interblock smoothing enabled.  This was a regression introduced by
> 	2.1 beta1[6(b)].
> 	5. Fixed two issues that prevented partial image decompression from working
> 	properly with buffered-image mode:
> 	     - Attempting to call `jpeg_crop_scanline()` after
> 	`jpeg_start_decompress()` but before `jpeg_start_output()` resulted in an error
> 	("Improper call to JPEG library in state 207".)
> 	     - Attempting to use `jpeg_skip_scanlines()` resulted in an error ("Bogus
> 	virtual array access") under certain circumstances.
>     2.1.3
> 	### Significant changes relative to 2.1.2
> 	1. Fixed a regression introduced by 2.0 beta1[7] whereby cjpeg compressed PGM
> 	input files into full-color JPEG images unless the `-grayscale` option was
> 	used.
> 	2. cjpeg now automatically compresses GIF and 8-bit BMP input files into
> 	grayscale JPEG images if the input files contain only shades of gray.
> 	3. The build system now enables the intrinsics implementation of the AArch64
> 	(Arm 64-bit) Neon SIMD extensions by default when using GCC 12 or later.
> 	4. Fixed a segfault that occurred while decompressing a 4:2:0 JPEG image using
> 	the merged (non-fancy) upsampling algorithms (that is, with
> 	`cinfo.do_fancy_upsampling` set to `FALSE`) along with `jpeg_crop_scanline()`.
> 	Specifically, the segfault occurred if the number of bytes remaining in the
> 	output buffer was less than the number of bytes required to represent one
> 	uncropped scanline of the output image.  For that reason, the issue could only
> 	be reproduced using the libjpeg API, not using djpeg.
>     2.1.2
> 	### Significant changes relative to 2.1.1
> 	1. Fixed a regression introduced by 2.1 beta1[13] that caused the remaining
> 	GAS implementations of AArch64 (Arm 64-bit) Neon SIMD functions (which are used
> 	by default with GCC for performance reasons) to be placed in the `.rodata`
> 	section rather than in the `.text` section.  This caused the GNU linker to
> 	automatically place the `.rodata` section in an executable segment, which
> 	prevented libjpeg-turbo from working properly with other linkers and also
> 	represented a potential security risk.
> 	2. Fixed an issue whereby the `tjTransform()` function incorrectly computed the
> 	MCU block size for 4:4:4 JPEG images with non-unary sampling factors and thus
> 	unduly rejected some cropping regions, even though those regions aligned with
> 	8x8 MCU block boundaries.
> 	3. Fixed a regression introduced by 2.1 beta1[13] that caused the build system
> 	to enable the Arm Neon SIMD extensions when targetting Armv6 and other legacy
> 	architectures that do not support Neon instructions.
> 	4. libjpeg-turbo now performs run-time detection of AltiVec instructions on
> 	FreeBSD/PowerPC systems if AltiVec instructions are not enabled at compile
> 	time.  This allows both AltiVec-equipped and non-AltiVec-equipped CPUs to be
> 	supported using the same build of libjpeg-turbo.
> 	5. cjpeg now accepts a `-strict` argument similar to that of djpeg and
> 	jpegtran, which causes the compressor to abort if an LZW-compressed GIF input
> 	image contains incomplete or corrupt image data.
>     2.1.1
> 	### Significant changes relative to 2.1.0
> 	1. Fixed a regression introduced in 2.1.0 that caused build failures with
> 	non-GCC-compatible compilers for Un*x/Arm platforms.
> 	2. Fixed a regression introduced by 2.1 beta1[13] that prevented the Arm 32-bit
> 	(AArch32) Neon SIMD extensions from building unless the C compiler flags
> 	included `-mfloat-abi=softfp` or `-mfloat-abi=hard`.
> 	3. Fixed an issue in the AArch32 Neon SIMD Huffman encoder whereby reliance on
> 	undefined C compiler behavior led to crashes ("SIGBUS: illegal alignment") on
> 	Android systems when running AArch32/Thumb builds of libjpeg-turbo built with
> 	recent versions of Clang.
> 	4. Added a command-line argument (`-copy icc`) to jpegtran that causes it to
> 	copy only the ICC profile markers from the source file and discard any other
> 	metadata.
> 	5. libjpeg-turbo should now build and run on CHERI-enabled architectures, which
> 	use capability pointers that are larger than the size of `size_t`.
> 	6. Fixed a regression (CVE-2021-37972) introduced by 2.1 beta1[5] that caused a
> 	segfault in the 64-bit SSE2 Huffman encoder when attempting to losslessly
> 	transform a specially-crafted malformed JPEG image.
>     2.1.0
> 	### Significant changes relative to 2.1 beta1
> 	1. Fixed a regression introduced by 2.1 beta1[6(b)] whereby attempting to
> 	decompress certain progressive JPEG images with one or more component planes of
> 	width 8 or less caused a buffer overrun.
> 	2. Fixed a regression introduced by 2.1 beta1[6(b)] whereby attempting to
> 	decompress a specially-crafted malformed progressive JPEG image caused the
> 	block smoothing algorithm to read from uninitialized memory.
> 	3. Fixed an issue in the Arm Neon SIMD Huffman encoders that caused the
> 	encoders to generate incorrect results when using the Clang compiler with
> 	Visual Studio.
> 	4. Fixed a floating point exception (CVE-2021-20205) that occurred when
> 	attempting to compress a specially-crafted malformed GIF image with a specified
> 	image width of 0 using cjpeg.
> 	5. Fixed a regression introduced by 2.0 beta1[15] whereby attempting to
> 	generate a progressive JPEG image on an SSE2-capable CPU using a scan script
> 	containing one or more scans with lengths divisible by 32 and non-zero
> 	successive approximation low bit positions would, under certain circumstances,
> 	result in an error ("Missing Huffman code table entry") and an invalid JPEG
> 	image.
> 	6. Introduced a new flag (`TJFLAG_LIMITSCANS` in the TurboJPEG C API and
> 	`TJ.FLAG_LIMIT_SCANS` in the TurboJPEG Java API) and a corresponding TJBench
> 	command-line argument (`-limitscans`) that causes the TurboJPEG decompression
> 	and transform functions/operations to return/throw an error if a progressive
> 	JPEG image contains an unreasonably large number of scans.  This allows
> 	applications that use the TurboJPEG API to guard against an exploit of the
> 	progressive JPEG format described in the report
> 	["Two Issues with the JPEG Standard"](https://libjpeg-turbo.org/pmwiki/uploads/About/TwoIssueswiththeJPEGStandard.pdf).
> 	7. The PPM reader now throws an error, rather than segfaulting (due to a buffer
> 	overrun) or generating incorrect pixels, if an application attempts to use the
> 	`tjLoadImage()` function to load a 16-bit binary PPM file (a binary PPM file
> 	with a maximum value greater than 255) into a grayscale image buffer or to load
> 	a 16-bit binary PGM file into an RGB image buffer.
> 	8. Fixed an issue in the PPM reader that caused incorrect pixels to be
> 	generated when using the `tjLoadImage()` function to load a 16-bit binary PPM
> 	file into an extended RGB image buffer.
> 	9. Fixed an issue whereby, if a JPEG buffer was automatically re-allocated by
> 	one of the TurboJPEG compression or transform functions and an error
> 	subsequently occurred during compression or transformation, the JPEG buffer
> 	pointer passed by the application was not updated when the function returned.
>     2.0.90 (2.1 beta1)
> 	### Significant changes relative to 2.0.6:
> 	1. The build system, x86-64 SIMD extensions, and accelerated Huffman codec now
> 	support the x32 ABI on Linux, which allows for using x86-64 instructions with
> 	32-bit pointers.  The x32 ABI is generally enabled by adding `-mx32` to the
> 	compiler flags.
> 	     Caveats:
> 	     - CMake 3.9.0 or later is required in order for the build system to
> 	automatically detect an x32 build.
> 	     - Java does not support the x32 ABI, and thus the TurboJPEG Java API will
> 	automatically be disabled with x32 builds.
> 	2. Added Loongson MMI SIMD implementations of the RGB-to-grayscale, 4:2:2 fancy
> 	chroma upsampling, 4:2:2 and 4:2:0 merged chroma upsampling/color conversion,
> 	and fast integer DCT/IDCT algorithms.  Relative to libjpeg-turbo 2.0.x, this
> 	speeds up:
> 	     - the compression of RGB source images into grayscale JPEG images by
> 	approximately 20%
> 	     - the decompression of 4:2:2 JPEG images by approximately 40-60% when
> 	using fancy upsampling
> 	     - the decompression of 4:2:2 and 4:2:0 JPEG images by approximately
> 	15-20% when using merged upsampling
> 	     - the compression of RGB source images by approximately 30-45% when using
> 	the fast integer DCT
> 	     - the decompression of JPEG images into RGB destination images by
> 	approximately 2x when using the fast integer IDCT
> 	    The overall decompression speedup for RGB images is now approximately
> 	2.3-3.7x (compared to 2-3.5x with libjpeg-turbo 2.0.x.)
> 	3. 32-bit (Armv7 or Armv7s) iOS builds of libjpeg-turbo are no longer
> 	supported, and the libjpeg-turbo build system can no longer be used to package
> 	such builds.  32-bit iOS apps cannot run in iOS 11 and later, and the App Store
> 	no longer allows them.
> 	4. 32-bit (i386) OS X/macOS builds of libjpeg-turbo are no longer supported,
> 	and the libjpeg-turbo build system can no longer be used to package such
> 	builds.  32-bit Mac applications cannot run in macOS 10.15 "Catalina" and
> 	later, and the App Store no longer allows them.
> 	5. The SSE2 (x86 SIMD) and C Huffman encoding algorithms have been
> 	significantly optimized, resulting in a measured average overall compression
> 	speedup of 12-28% for 64-bit code and 22-52% for 32-bit code on various Intel
> 	and AMD CPUs, as well as a measured average overall compression speedup of
> 	0-23% on platforms that do not have a SIMD-accelerated Huffman encoding
> 	implementation.
> 	6. The block smoothing algorithm that is applied by default when decompressing
> 	progressive Huffman-encoded JPEG images has been improved in the following
> 	ways:
> 	     - The algorithm is now more fault-tolerant.  Previously, if a particular
> 	scan was incomplete, then the smoothing parameters for the incomplete scan
> 	would be applied to the entire output image, including the parts of the image
> 	that were generated by the prior (complete) scan.  Visually, this had the
> 	effect of removing block smoothing from lower-frequency scans if they were
> 	followed by an incomplete higher-frequency scan.  libjpeg-turbo now applies
> 	block smoothing parameters to each iMCU row based on which scan generated the
> 	pixels in that row, rather than always using the block smoothing parameters for
> 	the most recent scan.
> 	     - When applying block smoothing to DC scans, a Gaussian-like kernel with a
> 	5x5 window is used to reduce the "blocky" appearance.
> 	7. Added SIMD acceleration for progressive Huffman encoding on Arm platforms.
> 	This speeds up the compression of full-color progressive JPEGs by about 30-40%
> 	on average (relative to libjpeg-turbo 2.0.x) when using modern Arm CPUs.
> 	8. Added configure-time and run-time auto-detection of Loongson MMI SIMD
> 	instructions, so that the Loongson MMI SIMD extensions can be included in any
> 	MIPS64 libjpeg-turbo build.
> 	9. Added fault tolerance features to djpeg and jpegtran, mainly to demonstrate
> 	methods by which applications can guard against the exploits of the JPEG format
> 	described in the report
> 	["Two Issues with the JPEG Standard"](https://libjpeg-turbo.org/pmwiki/uploads/About/TwoIssueswiththeJPEGStandard.pdf).
> 	     - Both programs now accept a `-maxscans` argument, which can be used to
> 	limit the number of allowable scans in the input file.
> 	     - Both programs now accept a `-strict` argument, which can be used to
> 	treat all warnings as fatal.
> 	10. CMake package config files are now included for both the libjpeg and
> 	TurboJPEG API libraries.  This facilitates using libjpeg-turbo with CMake's
> 	`find_package()` function.  For example:
> 	        find_package(libjpeg-turbo CONFIG REQUIRED)
> 	        add_executable(libjpeg_program libjpeg_program.c)
> 	        target_link_libraries(libjpeg_program PUBLIC libjpeg-turbo::jpeg)
> 	        add_executable(libjpeg_program_static libjpeg_program.c)
> 	        target_link_libraries(libjpeg_program_static PUBLIC
> 	          libjpeg-turbo::jpeg-static)
> 	        add_executable(turbojpeg_program turbojpeg_program.c)
> 	        target_link_libraries(turbojpeg_program PUBLIC
> 	          libjpeg-turbo::turbojpeg)
> 	        add_executable(turbojpeg_program_static turbojpeg_program.c)
> 	        target_link_libraries(turbojpeg_program_static PUBLIC
> 	          libjpeg-turbo::turbojpeg-static)
> 	11. Since the Unisys LZW patent has long expired, cjpeg and djpeg can now
> 	read/write both LZW-compressed and uncompressed GIF files (feature ported from
> 	jpeg-6a and jpeg-9d.)
> 	12. jpegtran now includes the `-wipe` and `-drop` options from jpeg-9a and
> 	jpeg-9d, as well as the ability to expand the image size using the `-crop`
> 	option.  Refer to jpegtran.1 or usage.txt for more details.
> 	13. Added a complete intrinsics implementation of the Arm Neon SIMD extensions,
> 	thus providing SIMD acceleration on Arm platforms for all of the algorithms
> 	that are SIMD-accelerated on x86 platforms.  This new implementation is
> 	significantly faster in some cases than the old GAS implementation--
> 	depending on the algorithms used, the type of CPU core, and the compiler.  GCC,
> 	as of this writing, does not provide a full or optimal set of Neon intrinsics,
> 	so for performance reasons, the default when building libjpeg-turbo with GCC is
> 	to continue using the GAS implementation of the following algorithms:
> 	     - 32-bit RGB-to-YCbCr color conversion
> 	     - 32-bit fast and accurate inverse DCT
> 	     - 64-bit RGB-to-YCbCr and YCbCr-to-RGB color conversion
> 	     - 64-bit accurate forward and inverse DCT
> 	     - 64-bit Huffman encoding
> 	    A new CMake variable (`NEON_INTRINSICS`) can be used to override this
> 	default.
> 	    Since the new intrinsics implementation includes SIMD acceleration
> 	for merged upsampling/color conversion, 1.5.1[5] is no longer necessary and has
> 	been reverted.
> 	14. The Arm Neon SIMD extensions can now be built using Visual Studio.
> 	15. The build system can now be used to generate a universal x86-64 + Armv8
> 	libjpeg-turbo SDK package for both iOS and macOS.
>     2.0.6
> 	### Significant changes relative to 2.0.5:
> 	1. Fixed "using JNI after critical get" errors that occurred on Android
> 	platforms when using any of the YUV encoding/compression/decompression/decoding
> 	methods in the TurboJPEG Java API.
> 	2. Fixed or worked around multiple issues with `jpeg_skip_scanlines()`:
> 	     - Fixed segfaults or "Corrupt JPEG data: premature end of data segment"
> 	errors in `jpeg_skip_scanlines()` that occurred when decompressing 4:2:2 or
> 	4:2:0 JPEG images using merged (non-fancy) upsampling/color conversion (that
> 	is, when setting `cinfo.do_fancy_upsampling` to `FALSE`.)  2.0.0[6] was a
> 	similar fix, but it did not cover all cases.
> 	     - `jpeg_skip_scanlines()` now throws an error if two-pass color
> 	quantization is enabled.  Two-pass color quantization never worked properly
> 	with `jpeg_skip_scanlines()`, and the issues could not readily be fixed.
> 	     - Fixed an issue whereby `jpeg_skip_scanlines()` always returned 0 when
> 	skipping past the end of an image.
> 	3. The Arm 64-bit (Armv8) Neon SIMD extensions can now be built using MinGW
> 	toolchains targetting Arm64 (AArch64) Windows binaries.
> 	4. Fixed unexpected visual artifacts that occurred when using
> 	`jpeg_crop_scanline()` and interblock smoothing while decompressing only the DC
> 	scan of a progressive JPEG image.
> 	5. Fixed an issue whereby libjpeg-turbo would not build if 12-bit-per-component
> 	JPEG support (`WITH_12BIT`) was enabled along with libjpeg v7 or libjpeg v8
> 	API/ABI emulation (`WITH_JPEG7` or `WITH_JPEG8`.)
>     2.0.5
> 	### Significant changes relative to 2.0.4:
> 	1. Worked around issues in the MIPS DSPr2 SIMD extensions that caused failures
> 	in the libjpeg-turbo regression tests.  Specifically, the
> 	`jsimd_h2v1_downsample_dspr2()` and `jsimd_h2v2_downsample_dspr2()` functions
> 	in the MIPS DSPr2 SIMD extensions are now disabled until/unless they can be
> 	fixed, and other functions that are incompatible with big endian MIPS CPUs are
> 	disabled when building libjpeg-turbo for such CPUs.
> 	2. Fixed an oversight in the `TJCompressor.compress(int)` method in the
> 	TurboJPEG Java API that caused an error ("java.lang.IllegalStateException: No
> 	source image is associated with this instance") when attempting to use that
> 	method to compress a YUV image.
> 	3. Fixed an issue (CVE-2020-13790) in the PPM reader that caused a buffer
> 	overrun in cjpeg, TJBench, or the `tjLoadImage()` function if one of the values
> 	in a binary PPM/PGM input file exceeded the maximum value defined in the file's
> 	header and that maximum value was less than 255.  libjpeg-turbo 1.5.0 already
> 	included a similar fix for binary PPM/PGM files with maximum values greater
> 	than 255.
> 	4. The TurboJPEG API library's global error handler, which is used in functions
> 	such as `tjBufSize()` and `tjLoadImage()` that do not require a TurboJPEG
> 	instance handle, is now thread-safe on platforms that support thread-local
> 	storage.
> 
> Signed-off-by: Adolf Belka <adolf.belka(a)ipfire.org>
> ---
>  config/rootfiles/common/libjpeg | 5 +++++
>  lfs/libjpeg                     | 6 +++---
>  2 files changed, 8 insertions(+), 3 deletions(-)
> 
> diff --git a/config/rootfiles/common/libjpeg b/config/rootfiles/common/libjpeg
> index eb74d2c50..74c101854 100644
> --- a/config/rootfiles/common/libjpeg
> +++ b/config/rootfiles/common/libjpeg
> @@ -9,6 +9,11 @@
>  #usr/include/jmorecfg.h
>  #usr/include/jpeglib.h
>  #usr/include/turbojpeg.h
> +#usr/lib/cmake/libjpeg-turbo
> +#usr/lib/cmake/libjpeg-turbo/libjpeg-turboConfig.cmake
> +#usr/lib/cmake/libjpeg-turbo/libjpeg-turboConfigVersion.cmake
> +#usr/lib/cmake/libjpeg-turbo/libjpeg-turboTargets-release.cmake
> +#usr/lib/cmake/libjpeg-turbo/libjpeg-turboTargets.cmake
>  #usr/lib/libjpeg.so
>  usr/lib/libjpeg.so.8
>  usr/lib/libjpeg.so.8.2.2
> diff --git a/lfs/libjpeg b/lfs/libjpeg
> index 6808640a4..b9c9d3cd8 100644
> --- a/lfs/libjpeg
> +++ b/lfs/libjpeg
> @@ -1,7 +1,7 @@
>  ###############################################################################
>  #                                                                             #
>  # IPFire.org - A linux based firewall                                         #
> -# Copyright (C) 2007-2020  IPFire Team  <info(a)ipfire.org>                     #
> +# Copyright (C) 2007-2022  IPFire Team  <info(a)ipfire.org>                     #
>  #                                                                             #
>  # This program is free software: you can redistribute it and/or modify        #
>  # it under the terms of the GNU General Public License as published by        #
> @@ -24,7 +24,7 @@
>  
>  include Config
>  
> -VER        = 2.0.4
> +VER        = 2.1.4
>  
>  THISAPP    = libjpeg-turbo-$(VER)
>  DL_FILE    = $(THISAPP).tar.gz
> @@ -40,7 +40,7 @@ objects = $(DL_FILE)
>  
>  $(DL_FILE) = $(DL_FROM)/$(DL_FILE)
>  
> -$(DL_FILE)_BLAKE2 = 9be870a5bafaae279646941b848b69fdf7c95ec08a686b01674f473ef33fe5923a04ba8a2d57df84384530308ca46fc3880a404c0eff769129417a553faed3bb
> +$(DL_FILE)_BLAKE2 = 80ffd77d58a37eae0bdc1868d994f34ea52c13e2624c720b1d0b6ec4d6d14b16911163ccd4009c8d6eda214f31e1fff78bb7eb4739ae6589d0fd8c7008c0e972
>  
>  install : $(TARGET)
>  

  reply	other threads:[~2022-12-27 16:12 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-12-27 11:59 [PATCH] curl: Update to version 7.87.0 Adolf Belka
2022-12-27 11:59 ` [PATCH] harfbuzz: Update to version 6.0.0 Adolf Belka
2022-12-29 11:21   ` Peter Müller
2022-12-27 11:59 ` [PATCH] libcap: Update to version 2.66 Adolf Belka
2022-12-29 11:20   ` Peter Müller
2022-12-27 11:59 ` [PATCH] libcdada: Update to version 0.4.0 Adolf Belka
2022-12-29 11:19   ` Peter Müller
2022-12-27 11:59 ` [PATCH] libconfig: Update to version 1.7.3 Adolf Belka
2022-12-27 11:59 ` [PATCH] libexif: Update to version 0.6.24 Adolf Belka
2022-12-27 16:15   ` Peter Müller
2022-12-27 11:59 ` [PATCH] libffi: Update to version 3.4.4 Adolf Belka
2022-12-27 16:13   ` Peter Müller
2022-12-27 11:59 ` [PATCH] libgpg-error: Update to version 1.46 Adolf Belka
2022-12-29 11:19   ` Peter Müller
2022-12-27 12:00 ` [PATCH] libidn: Update to version 1.41 Adolf Belka
2022-12-27 16:17   ` Peter Müller
2022-12-27 12:00 ` [PATCH] libinih: Update to version r56 Adolf Belka
2022-12-27 16:16   ` Peter Müller
2022-12-27 12:00 ` [PATCH] libjpeg: Update to version 2.1.4 Adolf Belka
2022-12-27 16:12   ` Peter Müller [this message]
2022-12-29 11:21 ` [PATCH] curl: Update to version 7.87.0 Peter Müller

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=0b6d94c6-ae7d-18d3-1cca-410f81c997ee@ipfire.org \
    --to=peter.mueller@ipfire.org \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox