Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp2133621pxb; Sat, 2 Oct 2021 07:41:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxFVyANj1a6Q5CbRb16yaTTXkG2/SwXY7EYbDp8h+Nmgf2k6/+lcBJqZrlKRhieaxYuZav2 X-Received: by 2002:a17:906:8396:: with SMTP id p22mr4466316ejx.140.1633185663569; Sat, 02 Oct 2021 07:41:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633185663; cv=none; d=google.com; s=arc-20160816; b=PIL5cYq1D3ZciNlWNuL1+7adwJ/6WWGsaDDcPDjMLLnH6YrTZejWJI0y8TytB8fRNg 2Vr6JuZvapOTAbq3AhwuQyIG2E6FzlTFZFEZ8WmD5XmNfSLSu69gWDJxXsXNnqpF2flI AJwvDklftsPqanCsuhhEz/NlzS22CMpYjgkGMLKOE82UUvwexpYzS+5hwXeKoVeEDhmf /aJw0nwYfgT2WolIZaxPz3kPvD16CoMx4vskqzm7xZrDxsM9n2N2EEesWNeXxT1u+ktF nvEr9XRdsfw5Pi30p3wxT8xGaPU5Ib+LqmkJ9aLBJLXnT/Pcri7mhfiFEhGNaqBHOWPs Cufg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=4AVH6fDKoa6JzB+sc4k7HhIqkbRVJlCDwp3u8GzP0OU=; b=UG/U4SOSN5+zlF6AzbO80OQNNvv9t98XvacV5mp9KpyIcFKFX1pfXPotxgcXYwZPOn KGciCWIX4/4wAEOerQ/k/AhnqvGpjUVc/fr5IdtqlNKX5M+OHr2IT8u8ReFLsgS/2G3k dkOJM2oedNM/NmDTzGPXR38KsUjLCE+2e8BqeB2DoIU6fTIDCjAHu7CNBvmfyQFsjAes vQQlEdM5BlfmzMCToErOUa2p2jLSB+Sh10cCBndn0F4l7BaiYT+7YUpE+rKKt5L7925J deIfnFVP595lxKvoz7yWapPS2yP4tIsqP70x/KsQoE7Uq8JWFRQX+qRm5oXA2DQd25Zj 8LWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@valentin-vidic.from.hr header.s=2020 header.b=C+ZwTcGx; 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=REJECT sp=REJECT dis=NONE) header.from=valentin-vidic.from.hr Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g18si7512081edt.383.2021.10.02.07.40.39; Sat, 02 Oct 2021 07:41:03 -0700 (PDT) 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=@valentin-vidic.from.hr header.s=2020 header.b=C+ZwTcGx; 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=REJECT sp=REJECT dis=NONE) header.from=valentin-vidic.from.hr Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233349AbhJBOjO (ORCPT + 99 others); Sat, 2 Oct 2021 10:39:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38574 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229560AbhJBOjN (ORCPT ); Sat, 2 Oct 2021 10:39:13 -0400 Received: from valentin-vidic.from.hr (valentin-vidic.from.hr [IPv6:2001:470:1f0b:3b7::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 84099C0613EC for ; Sat, 2 Oct 2021 07:37:26 -0700 (PDT) X-Virus-Scanned: Debian amavisd-new at valentin-vidic.from.hr Received: by valentin-vidic.from.hr (Postfix, from userid 1000) id 52F4371A3; Sat, 2 Oct 2021 16:37:18 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=valentin-vidic.from.hr; s=2020; t=1633185438; bh=4AVH6fDKoa6JzB+sc4k7HhIqkbRVJlCDwp3u8GzP0OU=; h=From:To:Cc:Subject:Date:From; b=C+ZwTcGxL0ePMgOl8BURH6qVeKGwxKxaDqP8/QqMAV76HfoHWCNQynzi+5cANHLih PYngqu6f/AB6etd4/hGb+jYdhgsB14422oM2W14dgU401vTEZkNrCcRCntGDqbVWKd 70unnBds2ggudOrUDKI24Umm0WBXTpaE+wQzS848EBC16+JFWVM8tRnMneb9MzrPkx WA/ss/A5rizrgHKkp6XWtsiw5hZs3mtu2JFOq+etcLEdqfiuYRpEyylQNb8zH3PsA/ Y1NQ5dwM9bFOqqwPRaKT0Yx9mCeLwBSdakiPrBK/KNxv2C+T2MwynTr8d01c8Zn0Hc C4PspsOvTPa0o7NSCAwTtx1zexwe11PJl5H69BS7i5Jc5QxxGhspVgSL4KkJpP6kDF pJlC2Jk7KTORuspbn39OXT/2b7CQ4/LYsCN26kUVBw06AeyuxR+0/08Mt8LMK47D3o pWAa1V812uWH5zrWRuNin9opUGgO0tPumFH2sXOC4AYmDeHR1aWgg4OatKU24MMptN Q4+ndGJJqJMD6yLpvrRbxoeW94LDVuGLdc0gQgDr2TDVmnshZI+GFGSNwrpIVpUo3s aOG/FBZ3YpEcnQ0bUHBdcVrSJMCsTbSkXmkmRRfM0IH5ONt27I+pIHVVjFn0mNMa9Z XJgwBi15Z6plW85PGTK7xyUw= From: Valentin Vidic To: Joseph Qi , Mark Fasheh , Joel Becker , ocfs2-devel@oss.oracle.com, linux-kernel@vger.kernel.org Cc: Valentin Vidic Subject: [PATCH] ocfs2: cleanup journal init and shutdown Date: Sat, 2 Oct 2021 16:36:40 +0200 Message-Id: <20211002143640.26512-1-vvidic@valentin-vidic.from.hr> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Allocate and free struct ocfs2_journal in ocfs2_journal_init and ocfs2_journal_shutdown. Init and release of system inodes references the journal so reorder calls to make sure they work correctly. Signed-off-by: Valentin Vidic --- fs/ocfs2/inode.c | 4 ++-- fs/ocfs2/journal.c | 25 +++++++++++++++++++++---- fs/ocfs2/journal.h | 3 +-- fs/ocfs2/super.c | 40 +++------------------------------------- 4 files changed, 27 insertions(+), 45 deletions(-) diff --git a/fs/ocfs2/inode.c b/fs/ocfs2/inode.c index bc8f32fab964..c2275895c229 100644 --- a/fs/ocfs2/inode.c +++ b/fs/ocfs2/inode.c @@ -125,7 +125,6 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno, unsigned flags, struct inode *inode = NULL; struct super_block *sb = osb->sb; struct ocfs2_find_inode_args args; - journal_t *journal = OCFS2_SB(sb)->journal->j_journal; trace_ocfs2_iget_begin((unsigned long long)blkno, flags, sysfile_type); @@ -172,10 +171,11 @@ struct inode *ocfs2_iget(struct ocfs2_super *osb, u64 blkno, unsigned flags, * part of the transaction - the inode could have been reclaimed and * now it is reread from disk. */ - if (journal) { + if (OCFS2_SB(sb)->journal) { transaction_t *transaction; tid_t tid; struct ocfs2_inode_info *oi = OCFS2_I(inode); + journal_t *journal = OCFS2_SB(sb)->journal->j_journal; read_lock(&journal->j_state_lock); if (journal->j_running_transaction) diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c index 4f15750aac5d..d50f0ac3fd46 100644 --- a/fs/ocfs2/journal.c +++ b/fs/ocfs2/journal.c @@ -810,19 +810,34 @@ void ocfs2_set_journal_params(struct ocfs2_super *osb) write_unlock(&journal->j_state_lock); } -int ocfs2_journal_init(struct ocfs2_journal *journal, int *dirty) +int ocfs2_journal_init(struct ocfs2_super *osb, int *dirty) { int status = -1; struct inode *inode = NULL; /* the journal inode */ journal_t *j_journal = NULL; + struct ocfs2_journal *journal = NULL; struct ocfs2_dinode *di = NULL; struct buffer_head *bh = NULL; - struct ocfs2_super *osb; int inode_lock = 0; - BUG_ON(!journal); + /* initialize our journal structure */ + journal = kzalloc(sizeof(struct ocfs2_journal), GFP_KERNEL); + if (!journal) { + mlog(ML_ERROR, "unable to alloc journal\n"); + status = -ENOMEM; + goto done; + } + osb->journal = journal; + journal->j_osb = osb; - osb = journal->j_osb; + atomic_set(&journal->j_num_trans, 0); + init_rwsem(&journal->j_trans_barrier); + init_waitqueue_head(&journal->j_checkpointed); + spin_lock_init(&journal->j_lock); + journal->j_trans_id = 1UL; + INIT_LIST_HEAD(&journal->j_la_cleanups); + INIT_WORK(&journal->j_recovery_work, ocfs2_complete_recovery); + journal->j_state = OCFS2_JOURNAL_FREE; /* already have the inode for our journal */ inode = ocfs2_get_system_file_inode(osb, JOURNAL_SYSTEM_INODE, @@ -1031,6 +1046,8 @@ void ocfs2_journal_shutdown(struct ocfs2_super *osb) // up_write(&journal->j_trans_barrier); done: iput(inode); + kfree(journal); + osb->journal = NULL; } static void ocfs2_clear_journal_error(struct super_block *sb, diff --git a/fs/ocfs2/journal.h b/fs/ocfs2/journal.h index d158acb8b38a..8dcb2f2cadbc 100644 --- a/fs/ocfs2/journal.h +++ b/fs/ocfs2/journal.h @@ -167,8 +167,7 @@ int ocfs2_compute_replay_slots(struct ocfs2_super *osb); * ocfs2_start_checkpoint - Kick the commit thread to do a checkpoint. */ void ocfs2_set_journal_params(struct ocfs2_super *osb); -int ocfs2_journal_init(struct ocfs2_journal *journal, - int *dirty); +int ocfs2_journal_init(struct ocfs2_super *osb, int *dirty); void ocfs2_journal_shutdown(struct ocfs2_super *osb); int ocfs2_journal_wipe(struct ocfs2_journal *journal, int full); diff --git a/fs/ocfs2/super.c b/fs/ocfs2/super.c index 5c914ce9b3ac..1286b88b6fa1 100644 --- a/fs/ocfs2/super.c +++ b/fs/ocfs2/super.c @@ -1894,8 +1894,6 @@ static void ocfs2_dismount_volume(struct super_block *sb, int mnt_err) /* This will disable recovery and flush any recovery work. */ ocfs2_recovery_exit(osb); - ocfs2_journal_shutdown(osb); - ocfs2_sync_blockdev(sb); ocfs2_purge_refcount_trees(osb); @@ -1918,6 +1916,8 @@ static void ocfs2_dismount_volume(struct super_block *sb, int mnt_err) ocfs2_release_system_inodes(osb); + ocfs2_journal_shutdown(osb); + /* * If we're dismounting due to mount error, mount.ocfs2 will clean * up heartbeat. If we're a local mount, there is no heartbeat. @@ -2016,7 +2016,6 @@ static int ocfs2_initialize_super(struct super_block *sb, int i, cbits, bbits; struct ocfs2_dinode *di = (struct ocfs2_dinode *)bh->b_data; struct inode *inode = NULL; - struct ocfs2_journal *journal; struct ocfs2_super *osb; u64 total_blocks; @@ -2197,33 +2196,6 @@ static int ocfs2_initialize_super(struct super_block *sb, get_random_bytes(&osb->s_next_generation, sizeof(u32)); - /* FIXME - * This should be done in ocfs2_journal_init(), but unknown - * ordering issues will cause the filesystem to crash. - * If anyone wants to figure out what part of the code - * refers to osb->journal before ocfs2_journal_init() is run, - * be my guest. - */ - /* initialize our journal structure */ - - journal = kzalloc(sizeof(struct ocfs2_journal), GFP_KERNEL); - if (!journal) { - mlog(ML_ERROR, "unable to alloc journal\n"); - status = -ENOMEM; - goto bail; - } - osb->journal = journal; - journal->j_osb = osb; - - atomic_set(&journal->j_num_trans, 0); - init_rwsem(&journal->j_trans_barrier); - init_waitqueue_head(&journal->j_checkpointed); - spin_lock_init(&journal->j_lock); - journal->j_trans_id = (unsigned long) 1; - INIT_LIST_HEAD(&journal->j_la_cleanups); - INIT_WORK(&journal->j_recovery_work, ocfs2_complete_recovery); - journal->j_state = OCFS2_JOURNAL_FREE; - INIT_WORK(&osb->dquot_drop_work, ocfs2_drop_dquot_refs); init_llist_head(&osb->dquot_drop_list); @@ -2404,7 +2376,7 @@ static int ocfs2_check_volume(struct ocfs2_super *osb) * ourselves. */ /* Init our journal object. */ - status = ocfs2_journal_init(osb->journal, &dirty); + status = ocfs2_journal_init(osb, &dirty); if (status < 0) { mlog(ML_ERROR, "Could not initialize journal!\n"); goto finally; @@ -2513,12 +2485,6 @@ static void ocfs2_delete_osb(struct ocfs2_super *osb) kfree(osb->osb_orphan_wipes); kfree(osb->slot_recovery_generations); - /* FIXME - * This belongs in journal shutdown, but because we have to - * allocate osb->journal at the start of ocfs2_initialize_osb(), - * we free it here. - */ - kfree(osb->journal); kfree(osb->local_alloc_copy); kfree(osb->uuid_str); kfree(osb->vol_label); -- 2.30.2