2 # Utility script to create an OBD snapshot. If an existing filesystem is
3 # not already mounted on /mnt/obd, we call the basic OBD setup script to
4 # create and mount a filesystem for us.
5 OBDDIR="`dirname $0`/.."
6 . $OBDDIR/demos/config.sh
9 # prepare the snapshot drive with a file to be COW'd
10 if [ ! -d /mnt/obd/lost+found ]; then
11 $OBDDIR/demos/obdfssetup.sh
12 if [ x$? != x0 ]; then
13 echo "Error running obdfssetup.sh"
18 if [ ! -f $MNTOBD/hello ]; then
19 $OBDDIR/demos/obdtest.sh
20 if [ x$? != x0 ]; then
21 echo "Error in obdfssetup.sh"
28 plog insmod $OBDDIR/snap/obdsnap.o
32 plog log "NEW SNAP SETUP"
33 # Create two snapshots using the OBD snapshot driver. One will be the
34 # "current" snapshot (in obd device 1), where changes will take place.
35 # The current snapshot is required in order to use the filesystem. The
36 # second will be a snapshot of the filesystem taken "now" (in obd device 2)
37 # that will remain static (historical read-only) filesystem as changes
38 # are made to the current snapshot.
39 $OBDDIR/class/obdcontrol -f << EOF
60 # Mount the two filesystems. The filesystem under $MNTOBD will be the
61 # one where changes are made, while $MNTSNAP will contain the original
62 # files at the point when the snapshot was taken.
64 [ ! -d "$MNTOBD" ] && mkdir $MNTOBD
65 [ ! -d "$MNTSNAP" ] && mkdir $MNTSNAP
66 plog mount -t obdfs -odevice=/dev/obd1 none $MNTOBD
67 plog mount -t obdfs -oro,device=/dev/obd2 none $MNTSNAP