Received: by 2002:a05:6520:2f93:b029:af:d4db:7a05 with SMTP id 19csp2378403lkf; Fri, 5 Feb 2021 11:34:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJwuOsWLWhwHuyOee9MxYEDIDl+Kb7g/Ptg8+M+GfH0CSI+hjfh68IOyfxEzVd41h7OL7oD8 X-Received: by 2002:aa7:d6d4:: with SMTP id x20mr5280138edr.8.1612553657284; Fri, 05 Feb 2021 11:34:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612553657; cv=none; d=google.com; s=arc-20160816; b=TuO0Pp5W0PXsuuQDvtXLDj+GthNs7v1OL5jR+TKRzsR2Q6g1ONjJfQEQldQNnd7I0N 9/yQGwEtVDliZKG4ICWhZ6quM8vVxCyxAHKyVplcb8y5eJf5wwBKI+MS40sLmJknA55Y +MBgcXtJCPr1KRPj5HZ6QDUFULkxJWpk0rMwuycTt5g8WmWRt5tN1zCTteogzvjBmM2u z7eevkZG/HPgNXyClWsD6lZAmLa0hdzGAKYVOqNKq9mX3uG7cenVd/R008WviMsNVrIC +oJBWA4L83YLSkwED6bRki2SD3dzyCyWeR5tV3b6X71rPgO5OlPOjPyGciKF5pjYRNhv iKtQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:dkim-signature:dkim-signature:from; bh=fABqgVHGSIcylUG/hBFzkYVB0r70cgGXiBucp9uc04g=; b=U0apEyC19F3YsKAKixSIMjj68YTsOzT9e0whE3YBrKQTIxibSGIcpGnqEXqPJukG11 lvApvzDaTpxYnXbPEuGxaIAlNK+u+r9sSE+4lM8YSvwKCQIwF7ND7xew8MTMOaEgFWFx rSoCQKHR/wneu+LZwibCqihdh0S6PjF78mTmPrzDfASmKjPM9KBwJh+MzDCb/lxSrZ8U QQ9pd7yyyax4NJ7WlaQI43zjUf+ItKuKrNfRSMrFJDb9kS9K30duqEANb/VOjd7L0Tb1 XR+kmZRGTIzrc2LhbaKeCmgJmpaT684/GYtdAntDm95QGC4UbwfbeutNB9O/YD+B3qBM Jdmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=na0TyHwy; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=bbg3NbnT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k9si6204651eje.254.2021.02.05.11.33.52; Fri, 05 Feb 2021 11:34:17 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=na0TyHwy; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=bbg3NbnT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233498AbhBERut (ORCPT + 99 others); Fri, 5 Feb 2021 12:50:49 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33430 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233297AbhBEPwS (ORCPT ); Fri, 5 Feb 2021 10:52:18 -0500 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3C957C061574 for ; Fri, 5 Feb 2021 09:34:00 -0800 (PST) From: Thomas Gleixner DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1612546438; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=fABqgVHGSIcylUG/hBFzkYVB0r70cgGXiBucp9uc04g=; b=na0TyHwyQApMrnZcFKRYY6AWioWymdq6m0snMWRPu2oUKUDnfSeeFXwJrPSf3eGPJT03vV 8aSqkAzIaI2fmeor2Fs3jyKJE7cJItmIKlYdfwWXXTBPTCyMXnwTM/PA904YsnZsXfUbOy gsHXVyyuvD1FZ1Y2+J4ILWzzjKiiKqiV/Nh1BQMG0f3JQSQS0ocGUTZTxQBmMSIlO5g3W2 jH1maVHL98eTRxffWfTEnXwmW+Cc2944QzegS/Qu2tzwSAfKWHSsSmvdGezHkHLW0KkjS1 rxhZwoW7BxZm214RqvdDUGPSgcJFQZUCKfBXkc/sutnGlpbaI3DDMxCyxVQTKg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1612546438; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=fABqgVHGSIcylUG/hBFzkYVB0r70cgGXiBucp9uc04g=; b=bbg3NbnTVfUPczQ4EBtYwAuQKvC8qBijv92iJsKiY+xwbNPWA28AbK49MWeUmLEW35C0id DJHCJ6y8dU6ZFjAQ== To: Yejune Deng , john.stultz@linaro.org, sboyd@kernel.org Cc: linux-kernel@vger.kernel.org, yejune.deng@gmail.com Subject: Re: [PATCH] ntp: use memset and offsetof init In-Reply-To: <20210120025114.16294-1-yejune.deng@gmail.com> References: <20210120025114.16294-1-yejune.deng@gmail.com> Date: Fri, 05 Feb 2021 18:33:58 +0100 Message-ID: <87k0rm8lmh.fsf@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 20 2021 at 10:51, Yejune Deng wrote: > In pps_fill_timex(), use memset and offsetof instead of '= 0'. > > Signed-off-by: Yejune Deng > --- > kernel/time/ntp.c | 13 +++++-------- > 1 file changed, 5 insertions(+), 8 deletions(-) > > diff --git a/kernel/time/ntp.c b/kernel/time/ntp.c > index 87389b9e21ab..3416c0381104 100644 > --- a/kernel/time/ntp.c > +++ b/kernel/time/ntp.c > @@ -225,14 +225,11 @@ static inline int is_error_status(int status) > static inline void pps_fill_timex(struct __kernel_timex *txc) > { > /* PPS is not implemented, so these are zero */ > - txc->ppsfreq = 0; > - txc->jitter = 0; > - txc->shift = 0; > - txc->stabil = 0; > - txc->jitcnt = 0; > - txc->calcnt = 0; > - txc->errcnt = 0; > - txc->stbcnt = 0; > + int offset, len; > + > + offset = offsetof(struct __kernel_timex, ppsfreq); > + len = offsetof(struct __kernel_timex, tai) - offset; > + memset(txc + offset, 0, len); That zeros bytes at a memory location which is (offset) * sizeof(struct __kernel_timex) bytes away from txc. How did this every boot? And no, even if you fix that pointer math problem then this kind of calculation from the middle of a struct is error prone. Thanks, tglx