mtd: require write permissions for locking and badblock ioctls
authorMichael Walle <michael@walle.cc>
Wed, 3 Mar 2021 15:57:35 +0000 (16:57 +0100)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Sun, 28 Mar 2021 17:20:11 +0000 (19:20 +0200)
commit1e97743fd180981bef5f01402342bb54bf1c6366
tree071f135ba46015e00f531351644d9e4afb5d3d82
parent3ba6d1ff041f07cfbbe1fdf0f25094590d7e543e
mtd: require write permissions for locking and badblock ioctls

MEMLOCK, MEMUNLOCK and OTPLOCK modify protection bits. Thus require
write permission. Depending on the hardware MEMLOCK might even be
write-once, e.g. for SPI-NOR flashes with their WP# tied to GND. OTPLOCK
is always write-once.

MEMSETBADBLOCK modifies the bad block table.

Fixes: f7e6b19bc764 ("mtd: properly check all write ioctls for permissions")
Signed-off-by: Michael Walle <michael@walle.cc>
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Acked-by: Rafał Miłecki <rafal@milecki.pl>
Acked-by: Richard Weinberger <richard@nod.at>
Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/linux-mtd/20210303155735.25887-1-michael@walle.cc
drivers/mtd/mtdchar.c