From patchwork Fri Jul 20 02:57:09 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: AKASHI Takahiro X-Patchwork-Id: 142411 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp2436731ljj; Thu, 19 Jul 2018 19:59:04 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfQeJIV8wvuZ7QVWd54/RXKLN1kZ4F724idmw6ePsvEsbcztUPqS4+lozuZFVx24kwP82su X-Received: by 2002:a50:b56e:: with SMTP id z43-v6mr518700edd.223.1532055544193; Thu, 19 Jul 2018 19:59:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532055544; cv=none; d=google.com; s=arc-20160816; b=ohuvBIqoaz2menBCxV/0aY6FL/LvFTaiuo0blCzl3+WrC5Xx0GTlM519rhg7jd/PEC 8AK4jIf5/B1iuERHwOedHPQaKeFUeuEH+ym5UQTKM1DLXex/SeglZLeFcyFPm1iwiIUe 2cH7o3zCPUS7lOHrjfy9IF9DZyEZ/9NoIu4yHbtawoDcHkDifnpRw8tGD4TEAJ3lvRP9 xRRzViNcw18YYmC124VuPvDWKptTAYNpUENlXdxWcTS1nMl6KlJrSB/7AYoWSGFZTPMi O2PTOab9bzcS577tM+ddHRtzRHDA2vGN1dllHrd1wMlzg9WYwvRQC/FhvXaRd93e6Hmw 6n3g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:mime-version :list-subscribe:list-help:list-post:list-archive:list-unsubscribe :list-id:precedence:subject:cc:references:in-reply-to:message-id :date:to:from:dkim-signature:arc-authentication-results; bh=fyjEkyvREvHbEwNvchgmf7/h3ctDwjQX1OIORAinxbI=; b=YJLOfReA6C8WUMtTHS1K7qQ7t1BE0AcNS535JMx5sRong9Zj1DTe8m7QBQna4lKg7B 7vC3mcgvkIUnouEmZ35pt1SEkCFOQM5zZIxhGW94zQtuD8T/xIpcLUvyKmv5euKjR7GZ am4236VYv1sbh0uJbFR0Qk98HhYFI/FnubtJZu8Pk86bqc6B9+4MUU3Pm6wFdWVuX81j Mi53EdbNY/ZO+xu4SN8c+xHbD2cV9KcmBLdfBcUMgh9Hs7B37sb97W+Fsj7EwWGSZtlP zR3vGR56L/NLsvZQb+VYZeG+WBjj1DnzHpezd/A/2acy3rScXJm4Kvf8/UUNTKA5rq2t YLQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=jAIeaLLZ; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.denx.de (dione.denx.de. [81.169.180.215]) by mx.google.com with ESMTP id x21-v6si505885edq.436.2018.07.19.19.59.03; Thu, 19 Jul 2018 19:59:04 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) client-ip=81.169.180.215; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=jAIeaLLZ; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: by lists.denx.de (Postfix, from userid 105) id AF434C21E26; Fri, 20 Jul 2018 02:57:55 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on lists.denx.de X-Spam-Level: X-Spam-Status: No, score=-0.0 required=5.0 tests=RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, T_DKIM_INVALID autolearn=unavailable autolearn_force=no version=3.4.0 Received: from lists.denx.de (localhost [IPv6:::1]) by lists.denx.de (Postfix) with ESMTP id 54E17C21C57; Fri, 20 Jul 2018 02:57:52 +0000 (UTC) Received: by lists.denx.de (Postfix, from userid 105) id B4B53C21E2B; Fri, 20 Jul 2018 02:57:05 +0000 (UTC) Received: from mail-pg1-f196.google.com (mail-pg1-f196.google.com [209.85.215.196]) by lists.denx.de (Postfix) with ESMTPS id 6907FC21E0F for ; Fri, 20 Jul 2018 02:57:01 +0000 (UTC) Received: by mail-pg1-f196.google.com with SMTP id p23-v6so5494674pgv.13 for ; Thu, 19 Jul 2018 19:57:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=oUvVfjwHXvS7E/oO9zmpCgL7lpT0efc4OCPjCK2fdg0=; b=jAIeaLLZNuvpDEOTJfailVXBAttUjGvRuuPmYBjL7GrNN9nT6E1Nz5yS2nibvZw20r 1PgNjcX+g/3ErcXCYlVWLnzQtp0LsANhQDd2fAK6Jaf25av7HSnAWep/6H9P7/eMajWG YnH9LCKm01/j8NjkBaVfaXPbKVjcAXV+gG7tY= 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=oUvVfjwHXvS7E/oO9zmpCgL7lpT0efc4OCPjCK2fdg0=; b=b3ofei8JR/C8FUtiBQdEt2Qlk3C1llHguEF3CzV5HDrU2q6pQc0AI9iky9UycBtCEG e6v5k1XghYGHNbYsnWDINICp/qE/cvhiakLJA0gEldYNX5RwmCqlS/hhVqxFLjve9+mH StiEWyMZF+j8VHJQl7FdSokaaswywUTES5Dz+w0L6W/twKr0OODeetTYY0Bga0c2cYxS 2GW3pr36OqEMzIAzd7E3dq8thFrGt3kP34JQ7eEqXsbt3148aPoGsYNhK0nkAiXyoFl+ nckj9Y5TLrzOBcUBbEe8z2OiXW39X4esWJTKZ0gxdny9C6dxJaq+AwyqLxGHp5UH97yo hlNQ== X-Gm-Message-State: AOUpUlGA0eqtnmpJu2FY1VE+QvOEgxgvgVjyRanyPFOPuO+OAJOYHCD2 ciC5Mja2j1ZNN0ik+k5dNu7TTA== X-Received: by 2002:a62:3f44:: with SMTP id m65-v6mr327067pfa.98.1532055420061; Thu, 19 Jul 2018 19:57:00 -0700 (PDT) Received: from linaro.org ([121.95.100.191]) by smtp.googlemail.com with ESMTPSA id a20-v6sm588421pfi.124.2018.07.19.19.56.59 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 19 Jul 2018 19:56:59 -0700 (PDT) From: AKASHI Takahiro To: trini@konsulko.com Date: Fri, 20 Jul 2018 11:57:09 +0900 Message-Id: <20180720025723.6736-4-takahiro.akashi@linaro.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180720025723.6736-1-takahiro.akashi@linaro.org> References: <20180720025723.6736-1-takahiro.akashi@linaro.org> Cc: u-boot@lists.denx.de, xypron.glpk@gmx.de, agraf@suse.de Subject: [U-Boot] [PATCH 03/17] fs: fat: make directory iterator global for write use X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.18 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" Directory iterator was introduced in major re-work of read operation by Rob. We want to use it for write operation extensively as well. This patch makes relevant functions, as well as iterator defition, visible outside of fat.c. Signed-off-by: AKASHI Takahiro --- fs/fat/fat.c | 39 ++++++--------------------------------- include/fat.h | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+), 33 deletions(-) diff --git a/fs/fat/fat.c b/fs/fat/fat.c index fd6523c66b..0f82cbe1bd 100644 --- a/fs/fat/fat.c +++ b/fs/fat/fat.c @@ -634,25 +634,6 @@ static int get_fs_info(fsdata *mydata) * For more complete example, see fat_itr_resolve() */ -typedef struct { - fsdata *fsdata; /* filesystem parameters */ - unsigned clust; /* current cluster */ - int last_cluster; /* set once we've read last cluster */ - int is_root; /* is iterator at root directory */ - int remaining; /* remaining dent's in current cluster */ - - /* current iterator position values: */ - dir_entry *dent; /* current directory entry */ - char l_name[VFAT_MAXLEN_BYTES]; /* long (vfat) name */ - char s_name[14]; /* short 8.3 name */ - char *name; /* l_name if there is one, else s_name */ - - /* storage for current cluster in memory: */ - u8 block[MAX_CLUSTSIZE] __aligned(ARCH_DMA_MINALIGN); -} fat_itr; - -static int fat_itr_isdir(fat_itr *itr); - /** * fat_itr_root() - initialize an iterator to start at the root * directory @@ -661,7 +642,7 @@ static int fat_itr_isdir(fat_itr *itr); * @fsdata: filesystem data for the partition * @return 0 on success, else -errno */ -static int fat_itr_root(fat_itr *itr, fsdata *fsdata) +int fat_itr_root(fat_itr *itr, fsdata *fsdata) { if (get_fs_info(fsdata)) return -ENXIO; @@ -693,7 +674,7 @@ static int fat_itr_root(fat_itr *itr, fsdata *fsdata) * @parent: the iterator pointing at a directory entry in the * parent directory of the directory to iterate */ -static void fat_itr_child(fat_itr *itr, fat_itr *parent) +void fat_itr_child(fat_itr *itr, fat_itr *parent) { fsdata *mydata = parent->fsdata; /* for silly macros */ unsigned clustnum = START(parent->dent); @@ -713,7 +694,7 @@ static void fat_itr_child(fat_itr *itr, fat_itr *parent) itr->last_cluster = 0; } -static void *next_cluster(fat_itr *itr) +void *next_cluster(fat_itr *itr) { fsdata *mydata = itr->fsdata; /* for silly macros */ int ret; @@ -834,7 +815,7 @@ static dir_entry *extract_vfat_name(fat_itr *itr) * @return boolean, 1 if success or 0 if no more entries in the * current directory */ -static int fat_itr_next(fat_itr *itr) +int fat_itr_next(fat_itr *itr) { dir_entry *dent; @@ -879,19 +860,11 @@ static int fat_itr_next(fat_itr *itr) * @itr: the iterator * @return true if cursor is at a directory */ -static int fat_itr_isdir(fat_itr *itr) +int fat_itr_isdir(fat_itr *itr) { return !!(itr->dent->attr & ATTR_DIR); } -/* - * Helpers: - */ - -#define TYPE_FILE 0x1 -#define TYPE_DIR 0x2 -#define TYPE_ANY (TYPE_FILE | TYPE_DIR) - /** * fat_itr_resolve() - traverse directory structure to resolve the * requested path. @@ -907,7 +880,7 @@ static int fat_itr_isdir(fat_itr *itr) * @type: bitmask of allowable file types * @return 0 on success or -errno */ -static int fat_itr_resolve(fat_itr *itr, const char *path, unsigned type) +int fat_itr_resolve(fat_itr *itr, const char *path, unsigned type) { const char *next; diff --git a/include/fat.h b/include/fat.h index 0c88b59a4a..577e6b4592 100644 --- a/include/fat.h +++ b/include/fat.h @@ -187,6 +187,38 @@ static inline u32 sect_to_clust(fsdata *fsdata, int sect) return (sect - fsdata->data_begin) / fsdata->clust_size; } +/* + * Directory iterator + */ + +#define TYPE_FILE 0x1 +#define TYPE_DIR 0x2 +#define TYPE_ANY (TYPE_FILE | TYPE_DIR) + +typedef struct { + fsdata *fsdata; /* filesystem parameters */ + unsigned clust; /* current cluster */ + int last_cluster; /* set once we've read last cluster */ + int is_root; /* is iterator at root directory */ + int remaining; /* remaining dent's in current cluster */ + + /* current iterator position values: */ + dir_entry *dent; /* current directory entry */ + char l_name[VFAT_MAXLEN_BYTES]; /* long (vfat) name */ + char s_name[14]; /* short 8.3 name */ + char *name; /* l_name if there is one, else s_name */ + + /* storage for current cluster in memory: */ + u8 block[MAX_CLUSTSIZE] __aligned(ARCH_DMA_MINALIGN); +} fat_itr; + +int fat_itr_root(fat_itr *itr, fsdata *fsdata); +void fat_itr_child(fat_itr *itr, fat_itr *parent); +void *next_cluster(fat_itr *itr); +int fat_itr_next(fat_itr *itr); +int fat_itr_isdir(fat_itr *itr); +int fat_itr_resolve(fat_itr *itr, const char *path, unsigned type); + int file_fat_detectfs(void); int fat_exists(const char *filename); int fat_size(const char *filename, loff_t *size);