187 lines
6.0 KiB
Python
187 lines
6.0 KiB
Python
# swap.py
|
|
# Device format classes for anaconda's storage configuration module.
|
|
#
|
|
# Copyright (C) 2009 Red Hat, Inc.
|
|
#
|
|
# This copyrighted material is made available to anyone wishing to use,
|
|
# modify, copy, or redistribute it subject to the terms and conditions of
|
|
# the GNU General Public License v.2, or (at your option) any later version.
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY expressed or implied, including the implied warranties of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
|
|
# Public License for more details. You should have received a copy of the
|
|
# GNU General Public License along with this program; if not, write to the
|
|
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
# 02110-1301, USA. Any Red Hat trademarks that are incorporated in the
|
|
# source code or documentation are not subject to the GNU General Public
|
|
# License and may only be used or replicated with the express permission of
|
|
# Red Hat, Inc.
|
|
#
|
|
# Red Hat Author(s): Dave Lehman <dlehman@redhat.com>
|
|
#
|
|
|
|
from iutil import numeric_type
|
|
from parted import PARTITION_SWAP, fileSystemType
|
|
from ..storage_log import log_method_call
|
|
from ..errors import *
|
|
from ..devicelibs import swap
|
|
from . import DeviceFormat, register_device_format
|
|
|
|
import gettext
|
|
_ = lambda x: gettext.ldgettext("anaconda", x)
|
|
|
|
import logging
|
|
log = logging.getLogger("storage")
|
|
|
|
|
|
class SwapSpace(DeviceFormat):
|
|
""" Swap space """
|
|
_type = "swap"
|
|
_name = None
|
|
_udevTypes = ["swap"]
|
|
partedFlag = PARTITION_SWAP
|
|
partedSystem = fileSystemType["linux-swap(v1)"]
|
|
_formattable = True # can be formatted
|
|
_supported = True # is supported
|
|
_linuxNative = True # for clearpart
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
""" Create a SwapSpace instance.
|
|
|
|
Keyword Arguments:
|
|
|
|
device -- path to the underlying device
|
|
uuid -- this swap space's uuid
|
|
label -- this swap space's label
|
|
priority -- this swap space's priority
|
|
exists -- indicates whether this is an existing format
|
|
|
|
"""
|
|
log_method_call(self, *args, **kwargs)
|
|
DeviceFormat.__init__(self, *args, **kwargs)
|
|
|
|
self.priority = kwargs.get("priority")
|
|
self.label = kwargs.get("label")
|
|
|
|
def __str__(self):
|
|
s = DeviceFormat.__str__(self)
|
|
s += (" priority = %(priority)s label = %(label)s" %
|
|
{"priority": self.priority, "label": self.label})
|
|
return s
|
|
|
|
@property
|
|
def dict(self):
|
|
d = super(SwapSpace, self).dict
|
|
d.update({"priority": self.priority, "label": self.label})
|
|
return d
|
|
|
|
def _setPriority(self, priority):
|
|
if priority is None:
|
|
self._priority = None
|
|
return
|
|
|
|
if not isinstance(priority, int) or not 0 <= priority <= 32767:
|
|
raise ValueError("swap priority must be an integer between 0 and 32767")
|
|
|
|
self._priority = priority
|
|
|
|
def _getPriority(self):
|
|
return self._priority
|
|
|
|
priority = property(_getPriority, _setPriority,
|
|
doc="The priority of the swap device")
|
|
|
|
def _getOptions(self):
|
|
opts = ""
|
|
if self.priority is not None:
|
|
opts += "pri=%d" % self.priority
|
|
|
|
return opts
|
|
|
|
def _setOptions(self, opts):
|
|
if not opts:
|
|
self.priority = None
|
|
return
|
|
|
|
for option in opts.split(","):
|
|
(opt, equals, arg) = option.partition("=")
|
|
if equals and opt == "pri":
|
|
try:
|
|
self.priority = int(arg)
|
|
except ValueError:
|
|
log.info("invalid value for swap priority: %s" % arg)
|
|
|
|
options = property(_getOptions, _setOptions,
|
|
doc="The swap device's fstab options string")
|
|
|
|
@property
|
|
def status(self):
|
|
""" Device status. """
|
|
return self.exists and swap.swapstatus(self.device)
|
|
|
|
def setup(self, *args, **kwargs):
|
|
""" Open, or set up, a device. """
|
|
log_method_call(self, device=self.device,
|
|
type=self.type, status=self.status)
|
|
if not self.exists:
|
|
raise SwapSpaceError("format has not been created")
|
|
|
|
if self.status:
|
|
return
|
|
|
|
DeviceFormat.setup(self, *args, **kwargs)
|
|
swap.swapon(self.device, priority=self.priority)
|
|
|
|
def teardown(self, *args, **kwargs):
|
|
""" Close, or tear down, a device. """
|
|
log_method_call(self, device=self.device,
|
|
type=self.type, status=self.status)
|
|
if not self.exists:
|
|
raise SwapSpaceError("format has not been created")
|
|
|
|
if self.status:
|
|
swap.swapoff(self.device)
|
|
|
|
def create(self, *args, **kwargs):
|
|
""" Create the device. """
|
|
log_method_call(self, device=self.device,
|
|
type=self.type, status=self.status)
|
|
intf = kwargs.get("intf")
|
|
force = kwargs.get("force")
|
|
if not force and self.exists:
|
|
raise SwapSpaceError("format already exists")
|
|
|
|
if force:
|
|
self.teardown()
|
|
elif self.status:
|
|
raise SwapSpaceError("device exists and is active")
|
|
|
|
w = None
|
|
if intf:
|
|
w = intf.progressWindow(_("Formatting"),
|
|
_("Creating %s on %s")
|
|
% (self.type,
|
|
kwargs.get("device", self.device)),
|
|
100, pulse = True)
|
|
|
|
try:
|
|
DeviceFormat.create(self, *args, **kwargs)
|
|
swap.mkswap(self.device, label=self.label, progress=w)
|
|
except Exception:
|
|
raise
|
|
else:
|
|
self.exists = True
|
|
finally:
|
|
if w:
|
|
w.pop()
|
|
|
|
def writeKS(self, f):
|
|
f.write("swap")
|
|
|
|
if self.label:
|
|
f.write(" --label=\"%s\"" % self.label)
|
|
|
|
|
|
register_device_format(SwapSpace)
|
|
|