Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 13 Aug 2007 16:27:39 -0400
From:      Howard Goldstein <hg@queue.to>
To:        scottl@samsco.org
Cc:        freebsd-stable@freebsd.org
Subject:   Re: 3ware RAID ctrlr: twe0: twe_map_request: malloc failed.
Message-ID:  <46C0BEBB.2060600@queue.to>
In-Reply-To: <46C0A812.7080702@samsco.org>
References:  <46C0A495.4060706@queue.to> <46C0A812.7080702@samsco.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Scott Long wrote:
> Howard Goldstein wrote:
>> Would someone confirm (or disabuse!) me of the belief that these 3ware
>> Escalade 8106-LP2 (2 port sata raid controllers) related messages are
>> informational and the UFS device is retrying after it sees ENOMEM
>> causing these?
>>
>> Aug 13 10:29:48 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 10:33:04 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 11:05:37 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 11:14:55 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 12:07:44 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 12:28:05 cally kernel: twe0: twe_map_request: malloc failed
>> Aug 13 14:29:59 cally kernel: twe0: twe_map_request: malloc failed
>>
>> (Either way but particularly in the event the data are being lost is
>> there a sysctl or kernel build option to supply a bit more memory in
>> advance?)
> 
> The system is doing unaligned I/O to the array (either via an app that
> has a file opened O_DIRECT, or via I/O directly to the device node), and
> there is corresponding memory pressure that is making the driver fail
> at the re-alignment process.  The problem is likely temporary and the
> operation eventually succeeds after a few retries, but success is not
> guaranteed, and failure will almost certainly cause system instability.
> The fix is to rewrite the alignment code in the driver to use the
> automatic, failure-free, alignment service that busdma provides.  I'm
> happy to provide direction to anyone who wants to tackle this.

Thank you Scott.  Might this be something I incited by not ensuring I
fdisked the drive with partitions on a somewhat larger boundary.  Will
rebuild the drive with more attention to placing the partitions on
something like 64K boundaries and see if it helps, otherwise I'll take
you up on your offer for a pointer to the busdma interface and tack a
whack at it.

FWIW, a misconfiguration does seem to be consistent with somewhat
degraded performance...

=



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?46C0BEBB.2060600>