Up until now, importing an SPDK RPC python module was just a matter of `import rpc`. It's fine until there's another module called `rpc` installed on the system, in which case it's impossible to import both of them. Therefore, to avoid this problem, all of the modules were moved to a separate directory under the "spdk" namespace. The decision to move to a location under a separate directory was motivated by the fact that a directory called scripts/spdk would look pretty confusing. Moreover, it should make it also easier to package these scripts as a python package. Other than moving the packages, all of the imports were updated to reflect these changes. Files under python now use relative imports, while those under scripts/ use the "spdk" namespace and have their PYTHONPATH extended with python directory. Signed-off-by: Konrad Sztyber <konrad.sztyber@intel.com> Change-Id: Ib43dee73921d590a551dd83885e22870e72451cf Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/9692 Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Community-CI: Broadcom CI <spdk-ci.pdl@broadcom.com> Community-CI: Mellanox Build Bot Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
58 lines
1.5 KiB
Python
58 lines
1.5 KiB
Python
def blobfs_detect(client, bdev_name):
|
|
"""Detect whether a blobfs exists on bdev.
|
|
|
|
Args:
|
|
bdev_name: block device name to detect blobfs
|
|
|
|
Returns:
|
|
True if a blobfs exists on the bdev; False otherwise.
|
|
"""
|
|
params = {
|
|
'bdev_name': bdev_name
|
|
}
|
|
return client.call('blobfs_detect', params)
|
|
|
|
|
|
def blobfs_create(client, bdev_name, cluster_sz=None):
|
|
"""Build blobfs on bdev.
|
|
|
|
Args:
|
|
bdev_name: block device name to build blobfs
|
|
cluster_sz: Size of cluster in bytes (Optional). Must be multiple of 4KB page size. Default and minimal value is 1M.
|
|
"""
|
|
params = {
|
|
'bdev_name': bdev_name
|
|
}
|
|
if cluster_sz:
|
|
params['cluster_sz'] = cluster_sz
|
|
return client.call('blobfs_create', params)
|
|
|
|
|
|
def blobfs_mount(client, bdev_name, mountpoint):
|
|
"""Mount blobfs on bdev by FUSE.
|
|
|
|
Args:
|
|
bdev_name: block device name where the blobfs is
|
|
mountpoint: Mountpoint path in host to mount blobfs
|
|
"""
|
|
params = {
|
|
'bdev_name': bdev_name,
|
|
'mountpoint': mountpoint
|
|
}
|
|
return client.call('blobfs_mount', params)
|
|
|
|
|
|
def blobfs_set_cache_size(client, size_in_mb):
|
|
"""Set cache size for the blobstore filesystem.
|
|
|
|
Args:
|
|
size_in_mb: Cache size in megabytes
|
|
|
|
Returns:
|
|
True if cache size is set successfully; False if failed to set.
|
|
"""
|
|
params = {
|
|
'size_in_mb': size_in_mb
|
|
}
|
|
return client.call('blobfs_set_cache_size', params)
|