From 3a4e355796891149adfd9228633f179015293dbd Mon Sep 17 00:00:00 2001 From: Richard Atkins Date: Wed, 21 Sep 2022 23:18:58 +1000 Subject: [PATCH] CVE-2022-42920 --- .../org/apache/bcel/classfile/ConstantPool.java | 15 +++++++++++---- .../org/apache/bcel/generic/ConstantPoolGen.java | 11 ++++++++++- 2 files changed, 21 insertions(+), 5 deletions(-) diff --git a/src/main/java/org/apache/bcel/classfile/ConstantPool.java b/src/main/java/org/apache/bcel/classfile/ConstantPool.java index f2c946a1..77ab0da4 100644 --- a/src/main/java/org/apache/bcel/classfile/ConstantPool.java +++ b/src/main/java/org/apache/bcel/classfile/ConstantPool.java @@ -218,10 +218,17 @@ public class ConstantPool implements Cloneable, Node { * @throws IOException */ public void dump( final DataOutputStream file ) throws IOException { - file.writeShort(constant_pool.length); - for (int i = 1; i < constant_pool.length; i++) { - if (constant_pool[i] != null) { - constant_pool[i].dump(file); + /* + * Constants over the size of the constant pool shall not be written out. + * This is a redundant measure as the ConstantPoolGen should have already + * reported an error back in the situation. + */ + final int size = Math.min(constant_pool.length, Const.MAX_CP_ENTRIES); + + file.writeShort(size); + for (int i = 1; i < size; i++) { + if (constant_pool[i] != null) { + constant_pool[i].dump(file); } } } diff --git a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java index fd0af47e..d3189ba4 100644 --- a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java +++ b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java @@ -95,7 +95,7 @@ public class ConstantPoolGen { public ConstantPoolGen(final Constant[] cs) { final StringBuilder sb = new StringBuilder(DEFAULT_BUFFER_SIZE); - size = Math.max(DEFAULT_BUFFER_SIZE, cs.length + 64); + size = Math.min(Math.max(DEFAULT_BUFFER_SIZE, cs.length + 64), Const.MAX_CP_ENTRIES + 1); constants = new Constant[size]; System.arraycopy(cs, 0, constants, 0, cs.length); @@ -224,9 +224,18 @@ public class ConstantPoolGen { /** Resize internal array of constants. */ protected void adjustSize() { + // 3 extra spaces are needed as some entries may take 3 slots + if (index + 3 >= Const.MAX_CP_ENTRIES + 1) { + throw new IllegalStateException("The number of constants " + (index + 3) + + " is over the size of the constant pool: " + + Const.MAX_CP_ENTRIES); + } + if (index + 3 >= size) { final Constant[] cs = constants; size *= 2; + // the constant array shall not exceed the size of the constant pool + size = Math.min(size, Const.MAX_CP_ENTRIES + 1); constants = new Constant[size]; System.arraycopy(cs, 0, constants, 0, index); } -- 2.38.1