2018-04-16 22:19:01 +02:00
|
|
|
From 7374ba0e53d8e6af4abbb02bd60f35ed541b94f5 Mon Sep 17 00:00:00 2001
|
|
|
|
From: David Disseldorp <ddiss@suse.de>
|
|
|
|
Date: Tue, 10 Apr 2018 16:22:54 +0200
|
2020-02-18 19:51:35 +01:00
|
|
|
Patch-mainline: never (SUSE-specific)
|
|
|
|
Subject: Split out blockdev readonly state detection helper
|
2018-04-16 22:19:01 +02:00
|
|
|
|
|
|
|
So that it can be reused for RBD backstores.
|
|
|
|
|
2020-02-18 19:51:35 +01:00
|
|
|
Note: not accepted upstream, but still needed
|
|
|
|
here for our rbd stuff. (lduncan@suse.com)
|
|
|
|
|
2018-04-16 22:19:01 +02:00
|
|
|
Signed-off-by: David Disseldorp <ddiss@suse.de>
|
|
|
|
---
|
2020-02-18 19:51:35 +01:00
|
|
|
targetcli/ui_backstore.py | 40 ++++++++++++++++++++--------------------
|
2018-04-16 22:19:01 +02:00
|
|
|
1 file changed, 20 insertions(+), 20 deletions(-)
|
|
|
|
|
|
|
|
--- a/targetcli/ui_backstore.py
|
|
|
|
+++ b/targetcli/ui_backstore.py
|
2020-02-18 19:51:35 +01:00
|
|
|
@@ -119,6 +119,25 @@ def complete_path(path, stat_fn):
|
2018-04-16 22:19:01 +02:00
|
|
|
return sorted(filtered,
|
|
|
|
key=lambda s: '~'+s if s.endswith('/') else s)
|
|
|
|
|
|
|
|
+def blk_dev_ro_check(dev):
|
|
|
|
+ BLKROGET=0x0000125E
|
|
|
|
+ try:
|
|
|
|
+ f = os.open(dev, os.O_RDONLY)
|
|
|
|
+ except (OSError, IOError):
|
|
|
|
+ raise ExecutionError("Could not open %s" % dev)
|
|
|
|
+ # ioctl returns an int. Provision a buffer for it
|
|
|
|
+ buf = array.array('b', [0] * 4)
|
|
|
|
+ try:
|
|
|
|
+ fcntl.ioctl(f, BLKROGET, buf)
|
|
|
|
+ except (OSError, IOError):
|
|
|
|
+ os.close(f)
|
|
|
|
+ return False
|
|
|
|
+
|
|
|
|
+ os.close(f)
|
|
|
|
+ if struct.unpack('I', buf)[0] == 0:
|
|
|
|
+ return False
|
|
|
|
+ return True
|
|
|
|
+
|
|
|
|
|
|
|
|
class UIALUATargetPortGroup(UIRTSLibNode):
|
|
|
|
'''
|
2020-02-18 19:51:35 +01:00
|
|
|
@@ -536,25 +555,6 @@ class UIBlockBackstore(UIBackstore):
|
2018-04-16 22:19:01 +02:00
|
|
|
self.so_cls = UIBlockStorageObject
|
|
|
|
UIBackstore.__init__(self, 'block', parent)
|
|
|
|
|
|
|
|
- def _ui_block_ro_check(self, dev):
|
|
|
|
- BLKROGET=0x0000125E
|
|
|
|
- try:
|
|
|
|
- f = os.open(dev, os.O_RDONLY)
|
|
|
|
- except (OSError, IOError):
|
|
|
|
- raise ExecutionError("Could not open %s" % dev)
|
|
|
|
- # ioctl returns an int. Provision a buffer for it
|
|
|
|
- buf = array.array('b', [0] * 4)
|
|
|
|
- try:
|
|
|
|
- fcntl.ioctl(f, BLKROGET, buf)
|
|
|
|
- except (OSError, IOError):
|
|
|
|
- os.close(f)
|
|
|
|
- return False
|
|
|
|
-
|
|
|
|
- os.close(f)
|
|
|
|
- if struct.unpack('I', buf)[0] == 0:
|
|
|
|
- return False
|
|
|
|
- return True
|
|
|
|
-
|
|
|
|
def ui_command_create(self, name, dev, readonly=None, wwn=None):
|
|
|
|
'''
|
2020-02-18 19:51:35 +01:00
|
|
|
Creates an Block Storage object. "dev" is the path to the TYPE_DISK
|
|
|
|
@@ -565,7 +565,7 @@ class UIBlockBackstore(UIBackstore):
|
2018-04-16 22:19:01 +02:00
|
|
|
ro_string = self.ui_eval_param(readonly, 'string', None)
|
|
|
|
if ro_string == None:
|
|
|
|
# attempt to detect block device readonly state via ioctl
|
|
|
|
- readonly = self._ui_block_ro_check(dev)
|
|
|
|
+ readonly = blk_dev_ro_check(dev)
|
|
|
|
else:
|
|
|
|
readonly = self.ui_eval_param(readonly, 'bool', False)
|
|
|
|
|