The Linux Kernel Mailing List
 help / color / mirror / Atom feed
* [PATCH] Support for read-only MMC cards
@ 2005-06-04 19:54 Pierre Ossman
  2005-06-04 19:58 ` Russell King
  0 siblings, 1 reply; 7+ messages in thread
From: Pierre Ossman @ 2005-06-04 19:54 UTC (permalink / raw)
  To: LKML, Russell King

[-- Attachment #1: Type: text/plain, Size: 131 bytes --]

If the card does not support the write commands then only allow
read-only access.

Signed-off-by: Pierre Ossman <drzeus@drzeus.cx>

[-- Attachment #2: mmc-ro_ccc.patch --]
[-- Type: text/x-patch, Size: 851 bytes --]

--- linux-2.6.11/drivers/mmc/mmc_block.c.orig	2005-06-04 21:44:20.000000000 +0200
+++ linux-2.6.11/drivers/mmc/mmc_block.c	2005-06-04 21:48:46.000000000 +0200
@@ -95,6 +95,10 @@ static int mmc_blk_open(struct inode *in
 		if (md->usage == 2)
 			check_disk_change(inode->i_bdev);
 		ret = 0;
+
+		if ((filp->f_mode & FMODE_WRITE) &&
+			!(md->queue.card->csd.cmdclass & CCC_BLOCK_WRITE))
+			ret = -EROFS;
 	}
 
 	return ret;
@@ -403,9 +407,12 @@ static int mmc_blk_probe(struct mmc_card
 	if (err)
 		goto out;
 
-	printk(KERN_INFO "%s: %s %s %dKiB\n",
+	printk(KERN_INFO "%s: %s %s %dKiB",
 		md->disk->disk_name, mmc_card_id(card), mmc_card_name(card),
 		(card->csd.capacity << card->csd.read_blkbits) / 1024);
+	if (!(card->csd.cmdclass & CCC_BLOCK_WRITE))
+		printk(" (ro)");
+	printk("\n");
 
 	mmc_set_drvdata(card, md);
 	add_disk(md->disk);

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2005-06-04 20:24 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-06-04 19:54 [PATCH] Support for read-only MMC cards Pierre Ossman
2005-06-04 19:58 ` Russell King
2005-06-04 20:05   ` Pierre Ossman
2005-06-04 20:07     ` Russell King
2005-06-04 20:14       ` Pierre Ossman
2005-06-04 20:16         ` Russell King
2005-06-04 20:24           ` Pierre Ossman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox