Re: ext2 on a CD-RW

From: Pavel Machek
Date: Sat Jan 03 2004 - 14:15:01 EST


Hi!

> > > > I thought some people here might find this amusing. After I
> > > > quick-formatted a CD-RW with cdrwtool today I then did the
> > > > following:
> > > >
> > > > mke2fs -b 2048 /dev/pktcdvd0
> > > >
> > > > It appears to work OK and I'm compiling a kernel on it as I type
> > > > this. pktcdvd can't handle this properly unless the '-b 2048' is
> > > > given for a pretty obvious reason. df tells me that the capacity of
> > > > a disc formatted like this is 530MB so there is a few MB lost
> > > > compared to UDF. I'm pretty sure this is a follish thing to do so
> > > > would anyone care to give me some technical reasons why? :)
> > >
> > > Yes, I have tested this too. It works in 2.4 but not in 2.5. In 2.5
> > > sr.c complains about unaligned transfers when I try to mount the
> > > filesystem. 2.4 has code (sr_scatter_pad) to handle unaligned
> > > transfers, but that code was removed in 2.5, and I havn't yet
> > > investigated how it is supposed to work without that code.
> >
> > There's supposed to be a reblocking player in the middle, ala loop. This
> > doesn't really work well for pktcdvd of course, so I'd suggest writing a
> > helper for reading and writing sub-block size units.
>
> I finally decided to investigate why this didn't work in the 2.5/2.6 code.
> (My tests were made with the 2.6.1-rc1 code and the latest packet patch.)
> There are two problems. The first is that the packet writing code forgot
> to set the hardsect size. This is fixed by the following patch.
>
> --- linux/drivers/block/pktcdvd.c.old 2004-01-02 00:23:57.000000000 +0100
> +++ linux/drivers/block/pktcdvd.c 2004-01-02 00:24:01.000000000 +0100
> @@ -2164,6 +2164,7 @@
> request_queue_t *q = disks[pkt_get_minor(pd)]->queue;
>
> blk_queue_make_request(q, pkt_make_request);
> + blk_queue_hardsect_size(q, CD_FRAMESIZE);
> blk_queue_max_sectors(q, PACKET_MAX_SECTORS);
> blk_queue_merge_bvec(q, pkt_merge_bvec);
> q->queuedata = pd;
>

Where do I get this file? It does not appear to be in 2.6.0.

[I have few partly-bad cd-rws, and putting ext2 on them would be
"cool" :-)]

Pavel
--
When do you have a heart between your knees?
[Johanka's followup: and *two* hearts?]
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/