Skip to content

Commit

Permalink
follow-up commit to r5403 - fix an out of bounds read access in optim…
Browse files Browse the repository at this point in the history
…ized_move_display_to_edited
  • Loading branch information
ddeclerck committed Dec 20, 2024
1 parent cb5fe73 commit 921108e
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 18 deletions.
45 changes: 27 additions & 18 deletions libcob/move.c
Original file line number Diff line number Diff line change
Expand Up @@ -1114,7 +1114,7 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
continue;
}
for (n = p->times_repeated; n > 0; n--) {
unsigned int src_num = COB_D2I (*src);
unsigned int src_num;
#ifndef NDEBUG
if (dst >= dst_end) {
cob_runtime_error ("optimized_move_display_to_edited: overflow in destination field");
Expand All @@ -1125,6 +1125,7 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)

case '9':
suppress_zero = 0;
src_num = COB_D2I (*src);
*dst = COB_I2D (src_num);
if (src_num != 0) {
is_zero = 0;
Expand All @@ -1134,6 +1135,7 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
break;

case 'Z':
src_num = COB_D2I (*src);
*dst = COB_I2D (src_num);
pad = ' ';
if (src_num != 0) {
Expand All @@ -1148,6 +1150,7 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
break;

case '*':
src_num = COB_D2I (*src);
*dst = COB_I2D (src_num);
have_check_protect = 1;
if (src_num != 0) {
Expand All @@ -1174,23 +1177,26 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
sign_position = dst;
dst++;
break;
} else if (src_num == 0 && suppress_zero && !have_decimal_point) {
*prev_float_char = ' ';
prev_float_char = dst;
sign_position = dst;
*dst = c;
dst++;
src++;
break;
} else {
*dst = COB_I2D (src_num);
if (src_num != 0) {
is_zero = 0;
suppress_zero = 0;
src_num = COB_D2I (*src);
if (src_num == 0 && suppress_zero && !have_decimal_point) {
*prev_float_char = ' ';
prev_float_char = dst;
sign_position = dst;
*dst = c;
dst++;
src++;
break;
} else {
*dst = COB_I2D (src_num);
if (src_num != 0) {
is_zero = 0;
suppress_zero = 0;
}
dst++;
src++;
break;
}
dst++;
src++;
break;
}

case '.':
Expand Down Expand Up @@ -1288,14 +1294,16 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
prev_float_char = dst;
dst++;
break;
} else if ((src_num == 0) && (suppress_zero) && (!have_decimal_point)) {
} else {
src_num = COB_D2I (*src);
if ((src_num == 0) && (suppress_zero) && (!have_decimal_point)) {
*prev_float_char = ' ';
prev_float_char = dst;
*dst = c;
dst++;
src++;
break;
} else {
} else {
*dst = COB_I2D (src_num);
if (src_num != 0) {
is_zero = 0;
Expand All @@ -1304,6 +1312,7 @@ optimized_move_display_to_edited (cob_field *f1, cob_field *f2)
dst++;
src++;
break;
}
}
}
}
Expand Down
24 changes: 24 additions & 0 deletions tests/testsuite.src/run_misc.at
Original file line number Diff line number Diff line change
Expand Up @@ -15202,3 +15202,27 @@ AT_CHECK([COB_PROF_ENABLE=1 COB_PROF_FILE=prof.csv $COBCRUN_DIRECT ./caller], [0
])

AT_CLEANUP


AT_SETUP([MOVE to NUMERIC-EDITED safety])

AT_DATA([prog.cob], [
IDENTIFICATION DIVISION.
PROGRAM-ID. prog.
DATA DIVISION.
WORKING-STORAGE SECTION.
01 X PIC 9(5) VALUE 12345.
01 Y PIC 9(5)CR.
PROCEDURE DIVISION.
MOVE X TO Y.
IF Y(1:) NOT = "12345" THEN
DISPLAY "EXPECTED '12345'"
DISPLAY "GOT '" Y(1:) "'"
END-IF.
STOP RUN.
])

AT_CHECK([$COMPILE prog.cob])
AT_CHECK([$COBCRUN_DIRECT ./prog], [0], [], [])

AT_CLEANUP

0 comments on commit 921108e

Please sign in to comment.