Ingo Oeser [ingo.oeser@informatik.tu-chemnitz.de] wrote:
> On Sun, Sep 02, 2001 at 05:59:38PM -0700, Larry McVoy wrote:
> > > What's needed is a generalisation of sparse files and truncate().
> > > They both handle similar problems.
> >
> > how about
> >
> > fzero(int fd, off_t off, size_t len)
> > fdelete(int fd, off_t off, size_t len)
>
> and
>
> finsert(int fd, off_t off, size_t len, void *buf, size_t buflen)
>
> > The main problem with this is if the off/len are not block aligned. If they
> > are, then this is just block twiddling, if they aren't, then this is a file
> > rewrite anyway.
*exactly* I don't know enough about ext2fs to know if this is possible
(i.e. a partially filled block in the middle of a file) so that's why I
asked.
> Another solution for the original problem is to rewrite the file
> in-place by coping from the end of the gap to the beginning of
> the gap until the gap is shifted to the end of the file and thus
> can be left to ftruncate().
For editing commercials, you'd still have to copy 90% of the data. In
the US, there's roughly 5 minutes of commercials for every 15 of the
show, so that would only save copying the first 15 minutes...
> This will at least not require more space on disk, but will take
> quite a while and risk data corruption for this file in case of
> abortion.
Yep. I should mention that the Linux/mjpeg tools
(http://mjpeg.sourceforge.net) already have an elegant way of "marking"
a portion of a video and skipping it when playing it, through the use of
"edit lists". (use xlav/glav to mark it, and then you can lavplay the
edit list, which just contains the start/end of skipped sections) They
also have a program to apply the edit list and create a new video
(lavtrans). But this requires copying the desired sections of video to
a new file, which requires 75% more disk space than the original file,
and takes a looong time.
The idea behind my first message should be obvious here...an almost
atomic operation modifying at most 2 blocks (and marking a bunch as
free) wouldn't require nearly as much disk-thrashing, and would be
nearly instantaneous from the user's perspective.
Disk fragmentation is unimportant when the contiguous chunks are 300MB
long.
> But fzero, fdelete and finsert might be worth considering, since
> some file systems, which pack tails could also pack these kind of
> partial used blocks and handle them properly.
Do the journaling filesystems use blocks in a similar manner to ext2fs?
Anyone know if any of them can handle partially filled blocks in the
middle of a file?
Are there any media-filesystems out there that have these kinds of
extensions? I'm not sure these extensions would be useful for anything
but editing media...
> We already handle partial pages, so why not handle them with
> offset/size pairs and enable this mechanisms? Multi media streams
> would love these kind of APIs ;-)
Yep yep yep. What do multimedia people use? Custom multi-thousand
dollar programs with their own filesystem layer? What about TiVo?
Didn't they contribute some fs-layer modifications a while back?
Cheers,
-- Bob
Bob McElrath (rsmcelrath@students.wisc.edu)
Univ. of Wisconsin at Madison, Department of Physics
This archive was generated by hypermail 2b29 : Fri Sep 07 2001 - 21:00:17 EST