Izik Eidus <[EMAIL PROTECTED]> writes: > (From v1 to v2 the main change is much more documentation) > > KSM is a linux driver that allows dynamicly sharing identical memory > pages between one or more processes. > > Unlike tradtional page sharing that is made at the allocation of the > memory, ksm do it dynamicly after the memory was created. > Memory is periodically scanned; identical pages are identified and > merged. > The sharing is unnoticeable by the process that use this memory. > (the shared pages are marked as readonly, and in case of write > do_wp_page() take care to create new copy of the page) > > This driver is very useful for KVM as in cases of runing multiple guests > operation system of the same type. Hi Izik, approach that was used in the driver commonly known as content based search. Where are several variants of it most commons are: 1: with guest TM support 2: w/o guest vm support. You have implemented second one, but seems it already was patented http://www.google.com/patents?vid=USPAT6789156 I'm not a lawyer but IMHO we have direct conflict here. >From other point of view they have patented the WEEL, but at least we have to know about this. > (For desktop work loads we have achived more than x2 memory overcommit > (more like x3)) > > This driver have found users other than KVM, for example CERN, > Fons Rademakers: > "on many-core machines we run one large detector simulation program per core. > These simulation programs are identical but run each in their own process and > need about 2 - 2.5 GB RAM. > We typically buy machines with 2GB RAM per core and so have a problem to run > one of these programs per core. > Of the 2 - 2.5 GB about 700MB is identical data in the form of magnetic field > maps, detector geometry, etc. > Currently people have been trying to start one program, initialize the > geometry > and field maps and then fork it N times, to have the data shared. > With KSM this would be done automatically by the system so it sounded > extremely > attractive when Andrea presented it." > > (We have are already started to test KSM on their systems...) > > KSM can run as kernel thread or as userspace application or both > > example for how to control the kernel thread: > > #include <stdio.h> > #include <stdlib.h> > #include <string.h> > #include <sys/types.h> > #include <sys/stat.h> > #include <sys/ioctl.h> > #include <fcntl.h> > #include <sys/mman.h> > #include <unistd.h> > #include "ksm.h" > > int main(int argc, char *argv[]) > { > int fd; > int used = 0; > int fd_start; > struct ksm_kthread_info info; > > > if (argc < 2) { > fprintf(stderr, > "usage: %s {start npages sleep | stop | info}\n", > argv[0]); > exit(1); > } > > fd = open("/dev/ksm", O_RDWR | O_TRUNC, (mode_t)0600); > if (fd == -1) { > fprintf(stderr, "could not open /dev/ksm\n"); > exit(1); > } > > if (!strncmp(argv[1], "start", strlen(argv[1]))) { > used = 1; > if (argc < 4) { > fprintf(stderr, > "usage: %s start npages_to_scan max_pages_to_merge sleep\n", > argv[0]); > exit(1); > } > info.pages_to_scan = atoi(argv[2]); > info.max_pages_to_merge = atoi(argv[3]); > info.sleep = atoi(argv[4]); > info.flags = ksm_control_flags_run; > > fd_start = ioctl(fd, KSM_START_STOP_KTHREAD, &info); > if (fd_start == -1) { > fprintf(stderr, "KSM_START_KTHREAD failed\n"); > exit(1); > } > printf("created scanner\n"); > } > > if (!strncmp(argv[1], "stop", strlen(argv[1]))) { > used = 1; > info.flags = 0; > fd_start = ioctl(fd, KSM_START_STOP_KTHREAD, &info); > printf("stopped scanner\n"); > } > > if (!strncmp(argv[1], "info", strlen(argv[1]))) { > used = 1; > ioctl(fd, KSM_GET_INFO_KTHREAD, &info); > printf("flags %d, pages_to_scan %d npages_merge %d, sleep_time %d\n", > info.flags, info.pages_to_scan, info.max_pages_to_merge, info.sleep); > } > > if (!used) > fprintf(stderr, "unknown command %s\n", argv[1]); > > return 0; > } > > example of how to register qemu to ksm (or any userspace application) > > diff --git a/qemu/vl.c b/qemu/vl.c > index 4721fdd..7785bf9 100644 > --- a/qemu/vl.c > +++ b/qemu/vl.c > @@ -21,6 +21,7 @@ > * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER > * DEALINGS IN > * THE SOFTWARE. > */ > +#include "ksm.h" > #include "hw/hw.h" > #include "hw/boards.h" > #include "hw/usb.h" > @@ -5799,6 +5800,37 @@ static void termsig_setup(void) > > #endif > > +int ksm_register_memory(void) > +{ > + int fd; > + int ksm_fd; > + int r = 1; > + struct ksm_memory_region ksm_region; > + > + fd = open("/dev/ksm", O_RDWR | O_TRUNC, (mode_t)0600); > + if (fd == -1) > + goto out; > + > + ksm_fd = ioctl(fd, KSM_CREATE_SHARED_MEMORY_AREA); > + if (ksm_fd == -1) > + goto out_free; > + > + ksm_region.npages = phys_ram_size / TARGET_PAGE_SIZE; > + ksm_region.addr = phys_ram_base; > + r = ioctl(ksm_fd, KSM_REGISTER_MEMORY_REGION, &ksm_region); > + if (r) > + goto out_free1; > + > + return r; > + > +out_free1: > + close(ksm_fd); > +out_free: > + close(fd); > +out: > + return r; > +} > + > int main(int argc, char **argv) > { > #ifdef CONFIG_GDBSTUB > @@ -6735,6 +6767,8 @@ int main(int argc, char **argv) > /* init the dynamic translator */ > cpu_exec_init_all(tb_size * 1024 * 1024); > > + ksm_register_memory(); > + > bdrv_init(); > > /* we always create the cdrom drive, even if no disk is there */ > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to [EMAIL PROTECTED] > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/
> LocalWords: Izik vm WEEL -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html