Date: Mon, 23 Apr 2012 13:58:57 GMT From: Petr Lampa <lampa@fit.vutbr.cz> To: freebsd-gnats-submit@FreeBSD.org Subject: kern/167226: new tbolt mfi driver cannot read sector >= 2^32 or 2^21 Message-ID: <201204231358.q3NDwuaD042630@red.freebsd.org> Resent-Message-ID: <201204231400.q3NE0auw012032@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 167226 >Category: kern >Synopsis: new tbolt mfi driver cannot read sector >= 2^32 or 2^21 >Confidential: no >Severity: critical >Priority: high >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: sw-bug >Submitter-Id: current-users >Arrival-Date: Mon Apr 23 14:00:35 UTC 2012 >Closed-Date: >Last-Modified: >Originator: Petr Lampa >Release: 9.0-STABLE >Organization: BUT FIT >Environment: FreeBSD temp 9.0-STABLE FreeBSD 9.0-STABLE #0: Thu Apr 19 11:18:42 CEST 2012 root@temp:/usr/obj/usr/src/sys/TEMP amd64 >Description: The new mfi_tbolt_build_cdb() ignores lba_hi when checking if lba address can be placed into read/write 6/10 CDB. The result is sector address clipped to 2^21-1 or 2^32-1 (this depends on request length). >How-To-Repeat: Connect 9265/9285 LSI MegaRAID and read existing array > 2TB. >Fix: Change dev/mfi/mfi_tbolt.c: if ((num_lba <= 0xFF) && (lba_lo <= 0x1FFFFF)) { .. else if ((num_lba <= 0xFFFF) && (lba_lo <= 0xFFFFFFFF)) { .. to if (lba_hi == 0 && (num_lba <= 0xFF) && (lba_lo <= 0x1FFFFF)) { ... else if (lba_hi == 0 && (num_lba <= 0xFFFF) && (lba_lo <= 0xFFFFFFFF)) { ... >Release-Note: >Audit-Trail: >Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201204231358.q3NDwuaD042630>