You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@orc.apache.org by "Quanlong Huang (Jira)" <ji...@apache.org> on 2022/05/03 04:23:00 UTC
[jira] [Resolved] (ORC-1159) [C++] Crash when the last stripe is skipped
[ https://issues.apache.org/jira/browse/ORC-1159?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Quanlong Huang resolved ORC-1159.
---------------------------------
Fix Version/s: 1.8.0
Resolution: Fixed
> [C++] Crash when the last stripe is skipped
> -------------------------------------------
>
> Key: ORC-1159
> URL: https://issues.apache.org/jira/browse/ORC-1159
> Project: ORC
> Issue Type: Bug
> Components: C++
> Affects Versions: 1.8.0
> Reporter: Quanlong Huang
> Assignee: Quanlong Huang
> Priority: Blocker
> Fix For: 1.8.0
>
> Attachments: alltypes_non_acid.orc
>
>
> I encountered a crash when using orc-scan to read the attached orc file with sargs "id < 10".
> {code:java}
> Program received signal SIGSEGV, Segmentation fault.
> 0x0000000000764039 in orc::RowReaderImpl::next (data=..., this=0xf67610) at /home/quanlong/workspace/orc/c++/src/Reader.cc:1153
> 1153 if (enableEncodedBlock) {
> (gdb) bt
> #0 0x0000000000764039 in orc::RowReaderImpl::next (data=..., this=0xf67610) at /home/quanlong/workspace/orc/c++/src/Reader.cc:1153
> #1 orc::RowReaderImpl::next (this=0xf67610, data=...) at /home/quanlong/workspace/orc/c++/src/Reader.cc:1122
> #2 0x0000000000745646 in scanFile(std::ostream&, char const*, unsigned long, orc::RowReaderOptions const&) () at /home/quanlong/workspace/orc/tools/src/FileScan.cc:34
> #3 0x0000000000741883 in main () at /home/quanlong/workspace/orc/tools/src/FileScan.cc:58
> #4 0x00007ffff68ab840 in __libc_start_main (main=0x7416c0 <main>, argc=2, argv=0x7fffffffdd48, init=<optimized out>, fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7fffffffdd38) at ../csu/libc-start.c:291
> #5 0x0000000000745479 in _start () at /home/quanlong/workspace/orc/tools/src/FileScan.cc:49
> (gdb) p reader
> $1 = std::unique_ptr<orc::ColumnReader> = {get() = 0x0}
> {code}
> Codes:
> {code:java}
> if (enableEncodedBlock) {
> reader->nextEncoded(data, rowsToRead, nullptr);
> }
> else {
> reader->next(data, rowsToRead, nullptr);
> }
> {code}
> {{reader}} is a nullptr thus the process crashes.
> The bug is introduced by a recent improvement (ORC-969). When startNextStripe() skippes all the remaining stripes, we should set rowsToRead to 0.
--
This message was sent by Atlassian Jira
(v8.20.7#820007)