[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CAK8P3a04ZmNU6zAyaJHnvm2m_9itHxhtVUd67kMEW-JXNdC8Rg@mail.gmail.com>
Date: Tue, 28 Nov 2017 14:27:18 +0100
From: Arnd Bergmann <arnd@...db.de>
To: Meelis Roos <mroos@...ux.ee>
Cc: Dave Carroll <david.carroll@...rosemi.com>,
"Martin K. Petersen" <martin.petersen@...cle.com>,
linux-scsi <linux-scsi@...r.kernel.org>,
Linux Kernel list <linux-kernel@...r.kernel.org>
Subject: Re: News UBSAN warnings in aacraid
On Tue, Nov 28, 2017 at 2:05 PM, Meelis Roos <mroos@...ux.ee> wrote:
>> I think this chunk would solve the problem and result in the
>> same behavior as before:
>>
>> --- a/drivers/scsi/aacraid/commsup.c
>> +++ b/drivers/scsi/aacraid/commsup.c
>> @@ -2511,8 +2511,8 @@ int aac_command_thread(void *data)
>> /* Synchronize our watches */
>> if (((NSEC_PER_SEC - (NSEC_PER_SEC / HZ)) > now.tv_nsec)
>> && (now.tv_nsec > (NSEC_PER_SEC / HZ)))
>> - difference = (((NSEC_PER_SEC -
>> now.tv_nsec) * HZ)
>> - + NSEC_PER_SEC / 2) / NSEC_PER_SEC;
>> + difference = HZ + HZ / 2 -
>> + now.tv_nsec / (NSEC_PER_SEC / HZ);
>> else {
>> if (now.tv_nsec > NSEC_PER_SEC / 2)
>> ++now.tv_sec;
>>
>> but I don't see why we add in half a second here. Any ideas?
>
> I did not try to understand the details but I can confirm that this
> patch makes the warnings go away.
Thanks for testing! I've wrote it up as a proper patch now, and tried
to capture what I understand about this code and how I got to
the new change.
Arnd
Powered by blists - more mailing lists