diff options
author | rwhitby <rwhitby@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2007-09-21 13:20:50 +0000 |
---|---|---|
committer | rwhitby <rwhitby@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2007-09-21 13:20:50 +0000 |
commit | 5753958314a65197196d014a7ced8f9d85d9b4b9 (patch) | |
tree | 727d27b3e1bc9530badf33c13a4f9b7d52cbe4cc /package/base-files | |
parent | 011b2b084a079d2b28b5bdc4bf173dbfb6da5187 (diff) |
Added support for /etc/default/fstab - a means of automatically mounting devices on boot.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@8916 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files')
-rw-r--r-- | package/base-files/Makefile | 2 | ||||
-rw-r--r-- | package/base-files/files/etc/config/fstab | 6 | ||||
-rwxr-xr-x | package/base-files/files/etc/init.d/fstab | 42 |
3 files changed, 49 insertions, 1 deletions
diff --git a/package/base-files/Makefile b/package/base-files/Makefile index c639df838..0cf96e2c8 100644 --- a/package/base-files/Makefile +++ b/package/base-files/Makefile @@ -10,7 +10,7 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/kernel.mk PKG_NAME:=base-files -PKG_RELEASE:=10 +PKG_RELEASE:=11 PKG_FILE_DEPEND:=$(PLATFORM_DIR)/ $(GENERIC_PLATFORM_DIR)/base-files/ diff --git a/package/base-files/files/etc/config/fstab b/package/base-files/files/etc/config/fstab new file mode 100644 index 000000000..28bb705a4 --- /dev/null +++ b/package/base-files/files/etc/config/fstab @@ -0,0 +1,6 @@ +config mount + option target /home + option device /dev/sda1 + option fstype ext3 + option options rw,sync + option enabled 0 diff --git a/package/base-files/files/etc/init.d/fstab b/package/base-files/files/etc/init.d/fstab new file mode 100755 index 000000000..2a63a5b1b --- /dev/null +++ b/package/base-files/files/etc/init.d/fstab @@ -0,0 +1,42 @@ +#!/bin/sh /etc/rc.common +# Copyright (C) 2007 OpenWrt.org + +START=20 + +do_mount() { + local cfg="$1" + config_get fstype "$cfg" fstype + fstype="${fstype:-auto}" + config_get options "$cfg" options + options="${options:-rw}" + config_get device "$cfg" device + [ -n "device" ] || return 0 + config_get target "$cfg" target + [ -n "target" ] || return 0 + mkdir -p $target + config_get_bool enabled "$cfg" "enabled" '1' + [ "$enabled" -gt 0 ] && { + /bin/mount -t $fstype -o $options $device $target + } +} + +do_unmount() { + local cfg="$1" + config_get target "$cfg" target + [ -n "target" ] || return 0 + config_get_bool enabled "$cfg" "enabled" '1' + [ "$enabled" -gt 0 ] && { + /bin/umount $target + } +} + +start() { + config_load fstab + config_foreach do_mount mount +} + +stop() { + config_load fstab + config_foreach do_unmount mount +} + |