RPC state of the RPC server, g_rpc_state is set by spdk_rpc_set_state(state). If the command line option '-w' is specified, g_rpc_state is initialized to SPDK_RPC_STARTUP. Otherwise, g_rpc_state is initialized to SPDK_RPC_RUNTIME. When g_rpc_state is initialized to SPDK_RPC_STARTUP, SPDK start RPC server and wait for start_subsystems_init RPC. When SPDK receive start_subsystems_init RPC, SPDK start initialization of subsystems. The RPC waits for completion of initialization of subsystems. When SPDK completes initialization of subsystems, SPDK change g_rpc_state to SPDK_RPC_RUNTIME and then start application. Upcoming new RPCs to initialize options of NVMf-tgt and iSCSI-tgt will be able to be allowed before start_subsystems_init RPC is called. Change-Id: I4fa9c22b64e2fdbc9b9fdb2c47f0018f73f84f7e Signed-off-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Reviewed-on: https://review.gerrithub.io/406919 Tested-by: SPDK Automated Test System <sys_sgsw@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Pawel Wodkowski <pawelx.wodkowski@intel.com> Reviewed-by: Daniel Verkamp <daniel.verkamp@intel.com> Reviewed-by: Ben Walker <benjamin.walker@intel.com>
69 lines
1.7 KiB
Python
Executable File
69 lines
1.7 KiB
Python
Executable File
import json
|
|
import sys
|
|
|
|
from . import app
|
|
from . import bdev
|
|
from . import iscsi
|
|
from . import log
|
|
from . import lvol
|
|
from . import nbd
|
|
from . import net
|
|
from . import nvmf
|
|
from . import pmem
|
|
from . import subsystem
|
|
from . import vhost
|
|
|
|
|
|
def start_subsystem_init(client):
|
|
return client.call('start_subsystem_init')
|
|
|
|
|
|
def get_rpc_methods(client):
|
|
return client.call('get_rpc_methods')
|
|
|
|
|
|
def save_config(client, args):
|
|
config = {
|
|
'subsystems': []
|
|
}
|
|
|
|
for elem in client.call('get_subsystems'):
|
|
cfg = {
|
|
'subsystem': elem['subsystem'],
|
|
'config': client.call('get_subsystem_config', {"name": elem['subsystem']})
|
|
}
|
|
config['subsystems'].append(cfg)
|
|
|
|
indent = args.indent
|
|
if args.filename is None:
|
|
if indent is None:
|
|
indent = 2
|
|
elif indent < 0:
|
|
indent = None
|
|
json.dump(config, sys.stdout, indent=indent)
|
|
sys.stdout.write('\n')
|
|
else:
|
|
if indent is None or indent < 0:
|
|
indent = None
|
|
with open(args.filename, 'w') as file:
|
|
json.dump(config, file, indent=indent)
|
|
file.write('\n')
|
|
|
|
|
|
def load_config(client, args):
|
|
if not args.filename or args.filename == '-':
|
|
config = json.load(sys.stdin)
|
|
else:
|
|
with open(args.filename, 'r') as file:
|
|
config = json.load(file)
|
|
|
|
for subsystem in config['subsystems']:
|
|
name = subsystem['subsystem']
|
|
config = subsystem['config']
|
|
if not config:
|
|
continue
|
|
for elem in subsystem['config']:
|
|
if not elem or 'method' not in elem:
|
|
continue
|
|
client.call(elem['method'], elem['params'])
|