Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1767559ybl; Sun, 18 Aug 2019 10:01:20 -0700 (PDT) X-Google-Smtp-Source: APXvYqxZfWMXhmfYA1NP7PSCdw3SR6QcepPpCn7TfNyjQZGadjt9TIzrvGqoxLuCMN2k8BYKMKe8 X-Received: by 2002:a17:90a:2846:: with SMTP id p6mr17107129pjf.101.1566147680299; Sun, 18 Aug 2019 10:01:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566147680; cv=none; d=google.com; s=arc-20160816; b=HgmUa0eQTFqXFPa5Fv2MllBnARfkx+Gqxr5m/ejzjldKkTC8Jad48Xou+WlUDghRMz 4ScSe9avBrs6hedB3gLBistA7OL7jabn5r1cztQq/lgQUnzpsyXVtttbWg3u6DXjCkqH M9LPQHzu47q1Up+p0mPX9BqzGVOoBlsxPtiYZJiR81/N/7gdn3i8c2zPSFWGAzQ/MK1n MplblOS01hvjXjKfklXQejDHFx/JMcYbV/71xdlTYVF/raU92gmWOOm5yX5ffZwKYB8r VvhuJW2c5fyKnDeVFPJAbs4G0FqCriraMbQ8t4k5PDpRk39GAW6G+d3dT2KPZA6Xhqxl MMDg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=ZDn2Y98kbbO22z0K+xR+AWtcv4GaQ+wX4PQ2vNgnGx0=; b=u0ZXPcGvaZXLNc7Sv2IyQj7U+lkfv42ToAa2Kg5S4Mvmz3AyEwD+5UPE8yI4G/hEPS 7hVsrONLYcKIM2aim9G2IvTdJpnGqyszl+WAcI5EqBC1AhsV/8WZ7VfGLeBWu2jJG3A8 SkkAkSrgArTZlzYnYOlOvU9DXM3uG29q1bdhEi6txdkG6LMnC+FqRpxYWMiVZeECoR4Z aG37VAYeRFW4Dy10ldVi9fzc9nLyvePlze22PJ1b/y6QO4S4ry47PE7TupFugsxhr3M9 G/MusgXyacgeWufLYrENqVC22u7uFdHjpshQbqMShVbAZXMRWJhodE9/xcoYbUNkUCVm dBcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=HZZECiva; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x6si8046306pgg.188.2019.08.18.10.01.06; Sun, 18 Aug 2019 10:01:20 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=HZZECiva; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727128AbfHRQ7w (ORCPT + 99 others); Sun, 18 Aug 2019 12:59:52 -0400 Received: from mail-pl1-f196.google.com ([209.85.214.196]:39837 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727117AbfHRQ7v (ORCPT ); Sun, 18 Aug 2019 12:59:51 -0400 Received: by mail-pl1-f196.google.com with SMTP id z3so4644620pln.6; Sun, 18 Aug 2019 09:59:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=ZDn2Y98kbbO22z0K+xR+AWtcv4GaQ+wX4PQ2vNgnGx0=; b=HZZECivaaHUGQpuuX/FAHVzlTJJLx3E0iyKj9ADCKY61mBIlC5TV6Os3rc0pFt/dsX KW+haRJEzqY16CKn9IDlmyyilH20DyykTBymCfAofasTklaRwyZo/hnoqEGvxfnBeduZ PKWJORpP5BCid1bVmi0Drt+kDcXrgwe7DOPlpA6/zveCSo9KO9uL2XF3NHSwduc1bkDI FqSFh8NhKnA2zZP9yFNfSNpDogJrGh1Twfb1cX5tNaeKwzI2l4Cta4NWdIT2+DiHKTHG wz4IzZdvnZ0+nCOZMpFFJkhk/dOFeJy5j5nUoUuOTIDnNoh9/uvfcMDkyHj0+XCJYFbU oLow== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=ZDn2Y98kbbO22z0K+xR+AWtcv4GaQ+wX4PQ2vNgnGx0=; b=VAEOC1RCvOHsNMXC3RJ9Mdh4C7NgxJlezRO+TbYLwcShyWjXnh+/pkwd5E+PuZJSE9 gV8PoFsE+tSSD8ZMiu+Vp3Vw9ozMfRozCfcEE39EbsVf8S+xFSF+kvzFSA/rZ8WgD9gj /Ou55M8sYPGC3vOtrT9K/9Nc4ynFEkeY0TgjLIFGPIcswbXTZBh+CcnLvsFmknqSXwcq vSoW5euLVid9ShOrO2+UxSps5tJgSQgW7zxaet/mtYFJSxf4RqUW80MPEK0eit4akxFs 49AWbaR0zcAdZIBtkjR887BQYrWvp3d9FoMQKDzzNZdBijSuDGrJ5U3dnvr1SRi3hWPl Ofkw== X-Gm-Message-State: APjAAAUYesR2noT8JbRYqsYTEznSHW3yOJKCbSn84Gdo4e/0WSLQyHwB acS978Ixb/mLVxjGdmOPYeM= X-Received: by 2002:a17:902:d90a:: with SMTP id c10mr18269442plz.208.1566147590877; Sun, 18 Aug 2019 09:59:50 -0700 (PDT) Received: from deepa-ubuntu.lan (c-98-234-52-230.hsd1.ca.comcast.net. [98.234.52.230]) by smtp.gmail.com with ESMTPSA id b136sm15732831pfb.73.2019.08.18.09.59.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 18 Aug 2019 09:59:50 -0700 (PDT) From: Deepa Dinamani To: viro@zeniv.linux.org.uk, linux-kernel@vger.kernel.org Cc: linux-fsdevel@vger.kernel.org, y2038@lists.linaro.org, arnd@arndb.de Subject: [PATCH v8 08/20] adfs: Fill in max and min timestamps in sb Date: Sun, 18 Aug 2019 09:58:05 -0700 Message-Id: <20190818165817.32634-9-deepa.kernel@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190818165817.32634-1-deepa.kernel@gmail.com> References: <20190818165817.32634-1-deepa.kernel@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Fill in the appropriate limits to avoid inconsistencies in the vfs cached inode times when timestamps are outside the permitted range. Note that the min timestamp is assumed to be 01 Jan 1970 00:00:00 (Unix epoch). This is consistent with the way we convert timestamps in adfs_adfs2unix_time(). Signed-off-by: Deepa Dinamani --- fs/adfs/adfs.h | 13 +++++++++++++ fs/adfs/inode.c | 8 ++------ fs/adfs/super.c | 2 ++ 3 files changed, 17 insertions(+), 6 deletions(-) diff --git a/fs/adfs/adfs.h b/fs/adfs/adfs.h index b7e844d2f321..dca8b23aa43f 100644 --- a/fs/adfs/adfs.h +++ b/fs/adfs/adfs.h @@ -3,6 +3,19 @@ #include #include +/* + * 01 Jan 1970 00:00:00 (Unix epoch) as seconds since + * 01 Jan 1900 00:00:00 (RISC OS epoch) + */ +#define RISC_OS_EPOCH_DELTA 2208988800LL + +/* + * Convert 40 bit centi seconds to seconds + * since 01 Jan 1900 00:00:00 (RISC OS epoch) + * The result is 2248-06-03 06:57:57 GMT + */ +#define ADFS_MAX_TIMESTAMP ((0xFFFFFFFFFFLL / 100) - RISC_OS_EPOCH_DELTA) + /* Internal data structures for ADFS */ #define ADFS_FREE_FRAG 0 diff --git a/fs/adfs/inode.c b/fs/adfs/inode.c index 124de75413a5..41eca1c451dc 100644 --- a/fs/adfs/inode.c +++ b/fs/adfs/inode.c @@ -167,11 +167,7 @@ static void adfs_adfs2unix_time(struct timespec64 *tv, struct inode *inode) { unsigned int high, low; - /* 01 Jan 1970 00:00:00 (Unix epoch) as nanoseconds since - * 01 Jan 1900 00:00:00 (RISC OS epoch) - */ - static const s64 nsec_unix_epoch_diff_risc_os_epoch = - 2208988800000000000LL; + static const s64 nsec_unix_epoch_diff_risc_os_epoch = RISC_OS_EPOCH_DELTA * NSEC_PER_SEC; s64 nsec; if (!adfs_inode_is_stamped(inode)) @@ -216,7 +212,7 @@ adfs_unix2adfs_time(struct inode *inode, unsigned int secs) if (adfs_inode_is_stamped(inode)) { /* convert 32-bit seconds to 40-bit centi-seconds */ low = (secs & 255) * 100; - high = (secs / 256) * 100 + (low >> 8) + 0x336e996a; + high = (secs / 256) * 100 + (low >> 8) + (RISC_OS_EPOCH_DELTA*100/256); ADFS_I(inode)->loadaddr = (high >> 24) | (ADFS_I(inode)->loadaddr & ~0xff); diff --git a/fs/adfs/super.c b/fs/adfs/super.c index 65b04ebb51c3..f074fe7d7158 100644 --- a/fs/adfs/super.c +++ b/fs/adfs/super.c @@ -463,6 +463,8 @@ static int adfs_fill_super(struct super_block *sb, void *data, int silent) asb->s_map_size = dr->nzones | (dr->nzones_high << 8); asb->s_map2blk = dr->log2bpmb - dr->log2secsize; asb->s_log2sharesize = dr->log2sharesize; + sb->s_time_min = 0; + sb->s_time_max = ADFS_MAX_TIMESTAMP; asb->s_map = adfs_read_map(sb, dr); if (IS_ERR(asb->s_map)) { -- 2.17.1