> From: Minchan Kim [mailto:minchan.kim@xxxxxxxxx] > > I am also eagerly awaiting Nitin Gupta's cleancache backend > > and implementation to do in-kernel page cache compression. > > Do Nitin say he will make backend of cleancache for > page cache compression? > > It would be good feature. > I have a interest, too. :) That was Nitin's plan for his GSOC project when we last discussed this. Nitin is on the cc list and can comment if this has changed. > > By "move", do you mean changing the virtual mappings? Yes, > > this could be done as long as the source and destination are > > both directly addressable (that is, true physical RAM), but > > requires TLB manipulation and has some complicated corner > > cases. The copy semantics simplifies the implementation on > > both the "frontend" and the "backend" and also allows the > > backend to do fancy things on-the-fly like page compression > > and page deduplication. > > Agree. But I don't mean it. > If I use brd as backend, i want to do it follwing as. > > <snip> > > Of course, I know it's impossible without new metadata and > modification of page cache handling and it makes front and > backend's good layered design. > > What I want is to remove copy overhead when backend is ram > and it's also part of main memory(ie, we have page descriptor). > > Do you have an idea? Copy overhead on modern processors is very low now due to very wide memory buses. The additional metadata and code to handle coherency and concurrency, plus existing overhead for batching and asynchronous access to brd is likely much higher than the cost to avoid copying. But if you did implement this without copying, I think you might need a different set of hooks in various places. I don't know. > > Or did you mean a cleancache_ops "backend"? For tmem, there > > is one file linux/drivers/xen/tmem.c and it interfaces between > > the cleancache_ops calls and Xen hypercalls. It should be in > > a Xenlinux pv_ops tree soon, or I can email it sooner. > > I mean "backend". :) I dropped the code used for a RHEL6beta Xen tmem driver here: http://oss.oracle.com/projects/tmem/dist/files/RHEL6beta/tmem-backend.patch Thanks, Dan -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxxx For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href