#
# loop.py
# loop device functions
#
# Copyright (C) 2010 Red Hat, Inc. All rights reserved.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty 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, see .
#
# Author(s): David Lehman
#
import os
from pyanaconda import iutil
from ..errors import *
import gettext
_ = lambda x: gettext.ldgettext("anaconda", x)
import logging
log = logging.getLogger("storage")
def losetup(args, capture=False):
if capture:
exec_func = iutil.execWithCapture
exec_kwargs = {}
else:
exec_func = iutil.execWithRedirect
exec_kwargs = {"stdout": "/dev/tty5"}
try:
# ask losetup what this loop device's backing device is
ret = exec_func("losetup", args,
stderr="/dev/tty5",
**exec_kwargs)
except RuntimeError as e:
raise LoopError(str(e))
return ret
def get_backing_file(name):
path = ""
sys_path = "/sys/class/block/%s/loop/backing_file" % name
if os.access(sys_path, os.R_OK):
path = open(sys_path).read().strip()
return path
def get_loop_name(path):
args = ["-j", path]
buf = losetup(args, capture=True)
if len(buf.splitlines()) > 1:
# there should never be more than one loop device listed
raise LoopError("multiple loops associated with %s" % path)
name = os.path.basename(buf.split(":")[0])
return name
def loop_setup(path):
args = ["-f", path]
msg = None
try:
msg = losetup(args)
except LoopError as e:
msg = str(e)
if msg:
raise LoopError("failed to set up loop for %s: %s" % (path, msg))
def loop_teardown(path):
args = ["-d", path]
msg = None
try:
msg = losetup(args)
except LoopError as e:
msg = str(e)
if msg:
raise DeviceError("failed to tear down loop %s: %s" % (path, msg))