RFR: 8349214: Improve size optimization flags for MSVC builds

Daniel Jeliński djelinski at openjdk.org
Tue Feb 4 12:55:27 UTC 2025


On Tue, 4 Feb 2025 08:51:43 GMT, Matthias Baesken <mbaesken at openjdk.org> wrote:

> Looks like the binary size optimization flags are not ideal when compiling with MSVC.
> On other compilers (gcc/clang) the current size optimization flags lead in most cases to smaller libraries. On MSVC this seems to be not the case, the libs often get larger when optimizing for SIZE.
> 
> For example jvm.dll (build with VS2022) with current -Os size optimization
> 20M images/jdk/bin/server/jvm.dll
> 
> with -O1 set for size optimization
> 13M images/jdk/bin/server/jvm.dll
> 
> See the doc from MSVC about "optimize for size"
> https://learn.microsoft.com/en-us/cpp/build/reference/o1-o2-minimize-size-maximize-speed?view=msvc-170
> "The /O1 option sets the individual optimization options that create the smallest code in the majority of cases."
> The Os option is only a part of the size minimization flag set :
> /O1 (Minimize Size) equivalent to /Og /Os /Oy /Ob2 /GF /Gy

No libraries are optimized for size by default.

Optimization for size is only used by hotspot, and only when `opt-size` feature is enabled; I think `opt-size` may be enabled in the `minimal` variant.

Optimization level `O1` is already used in many places, specifically in every place that uses `HIGH` or `LOW` optimization.

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

PR Comment: https://git.openjdk.org/jdk/pull/23432#issuecomment-2633821183


More information about the build-dev mailing list