Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2651972pxb; Sun, 24 Jan 2021 15:25:47 -0800 (PST) X-Google-Smtp-Source: ABdhPJyqX8To1E80jHQdjHhR4o7R0zLYrk7XN6R/VX9ExSSCy/eHHOQdy+XHZUD9ggJdzL6IAJ19 X-Received: by 2002:aa7:ca13:: with SMTP id y19mr207763eds.59.1611530747639; Sun, 24 Jan 2021 15:25:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611530747; cv=none; d=google.com; s=arc-20160816; b=Ud6IEqGquf7nzY8cT163mosczqZoDo3G93jYUdQp1KPx1MI0It2BEncSRaWM6S4tKc omwcR5QvnSOkmXUN1wwfcxmyW34hMOdr/68Un7LmKCG//Ot+VOMd0D23p+hrJXgm5x7l ofdF5NM3oH0skUfrISuoufrOsgxuwdlgCur/YMV29SlcegvIjA4xdD5NZoRZiJ3a9/Ex yqYYkGorZSn/dhMDEMduuxl9WpPG9UJoJ8mfaV4uYci7J3aNgojnhVoc9AnmrwrBfGl4 /lR1pV4Dc72GJus31aFyETrOI5NnM7D7Z5C62Fh8iqfBclftRx7oc8/CEoXdFI0qEOHe 6T4g== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=RrjwwI9onSt9Mv8I3dXISqDOKorNxmI8Pmc/nNCIyH4=; b=Hm4qlOJ0hJ/Byq18bfcqcrfAbE6aOkCEKFlTsnm5fu7f1Q9/mSFo5STVZWgq3TAXAu /Sd8QBObiEiAQmL9J24Q9+4KzgpeFRQcxeFz6QNMiYcR424GlBp11aHNKyyoezGr4Xh2 qagsGq2OvoQrNgw5abbf71EQoIdAq/T6lvYVlUcQnlzqJl2L3T5lIbxLgoVjXjN/mzr9 kb2vRsdNQhscIZCVsRDemn+ZRDe+16F8g/BDYu50LXyDQ3FUEnTWS22XqVK0ZVN+JlD7 pU+cMLEDro4MAfTzerMpfoRDATtIlfSCLrTtbpe31D0Oi5MNNppdu0uagR0Y+qD7JPEK xd6g== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g16si6402938edv.364.2021.01.24.15.25.24; Sun, 24 Jan 2021 15:25:47 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726247AbhAXXXa (ORCPT + 99 others); Sun, 24 Jan 2021 18:23:30 -0500 Received: from lilium.sigma-star.at ([109.75.188.150]:47182 "EHLO lilium.sigma-star.at" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726714AbhAXXWb (ORCPT ); Sun, 24 Jan 2021 18:22:31 -0500 Received: from localhost (localhost [127.0.0.1]) by lilium.sigma-star.at (Postfix) with ESMTP id C27B2180FCFCB; Mon, 25 Jan 2021 00:21:02 +0100 (CET) Received: from lilium.sigma-star.at ([127.0.0.1]) by localhost (lilium.sigma-star.at [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id 0zSQ5wgsYSEQ; Mon, 25 Jan 2021 00:21:02 +0100 (CET) Received: from lilium.sigma-star.at ([127.0.0.1]) by localhost (lilium.sigma-star.at [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id 2bhaQ0vUSK7X; Mon, 25 Jan 2021 00:21:02 +0100 (CET) From: Richard Weinberger To: miklos@szeredi.hu Cc: miquel.raynal@bootlin.com, vigneshr@ti.com, boris.brezillon@collabora.com, rminnich@google.com, sven@narfation.org, linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, fuse-devel@lists.sourceforge.net, Richard Weinberger Subject: [PATCH 6/8] fuse: Add MUSE specific defines FUSE interface Date: Mon, 25 Jan 2021 00:20:05 +0100 Message-Id: <20210124232007.21639-7-richard@nod.at> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20210124232007.21639-1-richard@nod.at> References: <20210124232007.21639-1-richard@nod.at> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Raise the FUSE API minor version to 34 and add all MUSE specific operations and data structures. MUSE_INIT: Initialize a new connection and installs the MTD MUSE_ERASE: Erases a block MUSE_READ: Reads a page with or without OOB MUSE_WRITE: Writes a page with or without OOB MUSE_MARKBAD: Marks a block as bad MUSE_ISBAD: Checks whether a block is bad MUSE_SYNC: Flushes all cached data Signed-off-by: Richard Weinberger --- include/uapi/linux/fuse.h | 76 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) diff --git a/include/uapi/linux/fuse.h b/include/uapi/linux/fuse.h index 98ca64d1beb6..1c8fa9e42e73 100644 --- a/include/uapi/linux/fuse.h +++ b/include/uapi/linux/fuse.h @@ -179,6 +179,10 @@ * 7.33 * - add FUSE_HANDLE_KILLPRIV_V2, FUSE_WRITE_KILL_SUIDGID, FATTR_KILL_S= UIDGID * - add FUSE_OPEN_KILL_SUIDGID + * + * 7.34 + * - add support for MUSE: MUSE_INIT, MUSE_ERASE, MUSE_READ, MUSE_WRITE= , + * MUSE_MARKBAD, MUSE_ISBAD and MUSE_SYNC */ =20 #ifndef _LINUX_FUSE_H @@ -503,6 +507,15 @@ enum fuse_opcode { /* CUSE specific operations */ CUSE_INIT =3D 4096, =20 + /* MUSE specific operations */ + MUSE_INIT =3D 8192, + MUSE_ERASE =3D 8193, + MUSE_READ =3D 8194, + MUSE_WRITE =3D 8195, + MUSE_MARKBAD =3D 8196, + MUSE_ISBAD =3D 8197, + MUSE_SYNC =3D 8198, + /* Reserved opcodes: helpful to detect structure endian-ness */ CUSE_INIT_BSWAP_RESERVED =3D 1048576, /* CUSE_INIT << 8 */ FUSE_INIT_BSWAP_RESERVED =3D 436207616, /* FUSE_INIT << 24 */ @@ -956,4 +969,67 @@ struct fuse_removemapping_one { #define FUSE_REMOVEMAPPING_MAX_ENTRY \ (PAGE_SIZE / sizeof(struct fuse_removemapping_one)) =20 +#define MUSE_INIT_INFO_MAX 4096 + +struct muse_init_in { + uint32_t fuse_major; + uint32_t fuse_minor; +}; + +struct muse_init_out { + uint32_t fuse_major; + uint32_t fuse_minor; + uint32_t max_read; + uint32_t max_write; +}; + +struct muse_erase_in { + uint64_t addr; + uint64_t len; +}; + +#define MUSE_IO_INBAND (1 << 0) +#define MUSE_IO_OOB_AUTO (1 << 1) +#define MUSE_IO_OOB_PLACE (1 << 2) +#define MUSE_IO_RAW (1 << 3) + +struct muse_read_in { + uint64_t addr; + uint64_t len; + uint32_t flags; + uint32_t padding; +}; + +struct muse_read_out { + uint64_t len; + uint32_t soft_error; + uint32_t padding; +}; + +struct muse_write_in { + uint64_t addr; + uint64_t len; + uint32_t flags; + uint32_t padding; +}; + +struct muse_write_out { + uint64_t len; + uint32_t soft_error; + uint32_t padding; +}; + +struct muse_markbad_in { + uint64_t addr; +}; + +struct muse_isbad_in { + uint64_t addr; +}; + +struct muse_isbad_out { + uint32_t result; + uint32_t padding; +}; + #endif /* _LINUX_FUSE_H */ --=20 2.26.2