Skip to content

Commit ca3e182

Browse files
sunshinecogitster
authored andcommitted
sequencer: fix "rebase -i --root" corrupting author header
When "git rebase -i --root" creates a new root commit (say, by swapping in a different commit for the root), it corrupts the commit's "author" header with trailing garbage: author A U Thor <[email protected]> @1112912773 [email protected] This is a result of read_author_ident() neglecting to NUL-terminate the buffer into which it composes the "author" header. (Note that the "@" preceding the timestamp and the extra "0" in the timezone are separate bugs which will be fixed subsequently.) Security considerations: Construction of the "author" header by read_author_ident() happens in-place and in parallel with parsing the content of "rebase-merge/author-script" which occupies the same buffer. This is possible because the constructed "author" header is always smaller than the content of "rebase-merge/author-script". Despite neglecting to NUL-terminate the constructed "author" header, memory is never accessed (either by read_author_ident() or its caller) beyond the allocated buffer since a NUL-terminator is present at the end of the loaded "rebase-merge/author-script" content, and additional NUL's are inserted as part of the parsing process. Signed-off-by: Eric Sunshine <[email protected]> Acked-by: Johannes Schindelin <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 53f9a3e commit ca3e182

File tree

2 files changed

+10
-2
lines changed

2 files changed

+10
-2
lines changed

sequencer.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -741,7 +741,7 @@ static const char *read_author_ident(struct strbuf *buf)
741741
return NULL;
742742
}
743743

744-
buf->len = out - buf->buf;
744+
strbuf_setlen(buf, out - buf->buf);
745745
return buf->buf;
746746
}
747747

t/t3404-rebase-interactive.sh

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1202,7 +1202,7 @@ rebase_setup_and_clean () {
12021202
test_might_fail git branch -D $1 &&
12031203
test_might_fail git rebase --abort
12041204
" &&
1205-
git checkout -b $1 master
1205+
git checkout -b $1 ${2:-master}
12061206
}
12071207

12081208
test_expect_success 'drop' '
@@ -1379,4 +1379,12 @@ test_expect_success 'rebase -i --gpg-sign=<key-id> overrides commit.gpgSign' '
13791379
test_i18ngrep "$SQ-S\"S I Gner\"$SQ" err
13801380
'
13811381

1382+
test_expect_success 'valid author header after --root swap' '
1383+
rebase_setup_and_clean author-header no-conflict-branch &&
1384+
set_fake_editor &&
1385+
FAKE_LINES="2 1" git rebase -i --root &&
1386+
git cat-file commit HEAD^ >out &&
1387+
grep "^author ..*> @[0-9][0-9]* [-+][0-9][0-9]*$" out
1388+
'
1389+
13821390
test_done

0 commit comments

Comments
 (0)