[bug report] staging: erofs: tidy up decompression frontend
Dan Carpenter
dan.carpenter at oracle.com
Tue Aug 27 19:53:47 AEST 2019
On Tue, Aug 27, 2019 at 05:36:29PM +0800, Gao Xiang wrote:
> Hi Dan,
>
> Thanks for your report.
>
> On Tue, Aug 27, 2019 at 12:03:55PM +0300, Dan Carpenter wrote:
> > Hello Gao Xiang,
> >
> > This is a semi-automatic email about new static checker warnings.
> >
> > The patch 97e86a858bc3: "staging: erofs: tidy up decompression
> > frontend" from Jul 31, 2019, leads to the following Smatch complaint:
> >
> > fs/erofs/zdata.c:670 z_erofs_do_read_page()
> > error: we previously assumed 'clt->cl' could be null (see line 596)
> >
> > fs/erofs/zdata.c
> > 595 /* didn't get a valid collection previously (very rare) */
> > 596 if (!clt->cl)
> > ^^^^^^^^
> > New NULL check.
> >
> > 597 goto restart_now;
> > 598 goto hitted;
> > 599 }
> > 600
> > 601 /* go ahead the next map_blocks */
> > 602 debugln("%s: [out-of-range] pos %llu", __func__, offset + cur);
> > 603
> > 604 if (z_erofs_collector_end(clt))
> > 605 fe->backmost = false;
> > 606
> > 607 map->m_la = offset + cur;
> > 608 map->m_llen = 0;
> > 609 err = z_erofs_map_blocks_iter(inode, map, 0);
> > 610 if (unlikely(err))
> > 611 goto err_out;
> > 612
> > 613 restart_now:
> > 614 if (unlikely(!(map->m_flags & EROFS_MAP_MAPPED)))
> > 615 goto hitted;
> > 616
> > 617 err = z_erofs_collector_begin(clt, inode, map);
>
> At a glance, clt->cl will be all initialized in all successful paths
> in z_erofs_collector_begin, or it all fall back into err_out...
> I have no idea what is wrong here...
>
> Some detailed path from Smatch for NIL dereferences?
>
Ah. Sorry for that. It's a false positive. I will investigate and
fix Smatch.
regards,
dan carpenter
More information about the Linux-erofs
mailing list