From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:44374) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1gXng3-00079d-Oe for qemu-devel@nongnu.org; Fri, 14 Dec 2018 08:38:52 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1gXng0-0003iJ-JQ for qemu-devel@nongnu.org; Fri, 14 Dec 2018 08:38:51 -0500 Date: Fri, 14 Dec 2018 14:38:40 +0100 From: Cornelia Huck Message-ID: <20181214143840.123b1549.cohuck@redhat.com> In-Reply-To: <1544792887-14575-1-git-send-email-thuth@redhat.com> References: <1544792887-14575-1-git-send-email-thuth@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH] hw/s390x: Fix bad mask in time2tod() List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Thomas Huth Cc: qemu-s390x@nongnu.org, qemu-devel@nongnu.org, Halil Pasic , Christian Borntraeger , David Hildenbrand , qemu-stable@nongnu.org On Fri, 14 Dec 2018 14:08:07 +0100 Thomas Huth wrote: > The time2tod() function tries to deal with the 9 uppermost bits in the > time value, but uses the wrong mask for this: 0xff80000000000000 should > be used instead of 0xff10000000000000 here. I've tweaked this to Since "s390x/tcg: avoid overflows in time2tod/tod2time", the time2tod() function tries to deal with the 9 uppermost bits in the time value, but uses the wrong mask for this: 0xff80000000000000 should be used instead of 0xff10000000000000 here. > > Fixes: 14055ce53c2d901d826ffad7fb7d6bb8ab46bdfd I'll add cc:stable in the patch description as well. > Signed-off-by: Thomas Huth > --- > include/hw/s390x/tod.h | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/include/hw/s390x/tod.h b/include/hw/s390x/tod.h > index cbd7552..47ef9de 100644 > --- a/include/hw/s390x/tod.h > +++ b/include/hw/s390x/tod.h > @@ -56,7 +56,7 @@ typedef struct S390TODClass { > /* Converts ns to s390's clock format */ > static inline uint64_t time2tod(uint64_t ns) > { > - return (ns << 9) / 125 + (((ns & 0xff10000000000000ull) / 125) << 9); > + return (ns << 9) / 125 + (((ns & 0xff80000000000000ull) / 125) << 9); > } > > /* Converts s390's clock format to ns */ Thanks, applied.