xref: /spdk/module/bdev/zone_block/vbdev_zone_block_rpc.c (revision c77bc554d2ad0e23cb1c2418f70a6027f1775b37)
1488570ebSJim Harris /*   SPDX-License-Identifier: BSD-3-Clause
2a6dbe372Spaul luse  *   Copyright (C) 2019 Intel Corporation.
3*c77bc554SShuhei Matsumoto  *   Copyright (c) 2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
4195be29eSMateusz Kozlowski  *   All rights reserved.
5195be29eSMateusz Kozlowski  */
6195be29eSMateusz Kozlowski 
7195be29eSMateusz Kozlowski #include "spdk/stdinc.h"
8195be29eSMateusz Kozlowski 
9195be29eSMateusz Kozlowski #include "vbdev_zone_block.h"
10195be29eSMateusz Kozlowski 
11195be29eSMateusz Kozlowski #include "spdk/util.h"
12195be29eSMateusz Kozlowski #include "spdk/string.h"
13195be29eSMateusz Kozlowski #include "spdk/rpc.h"
14195be29eSMateusz Kozlowski 
154e8e97c8STomasz Zawadzki #include "spdk/log.h"
16195be29eSMateusz Kozlowski 
17195be29eSMateusz Kozlowski struct rpc_construct_zone_block {
18195be29eSMateusz Kozlowski 	char *name;
19195be29eSMateusz Kozlowski 	char *base_bdev;
20195be29eSMateusz Kozlowski 	uint64_t zone_capacity;
21195be29eSMateusz Kozlowski 	uint64_t optimal_open_zones;
22195be29eSMateusz Kozlowski };
23195be29eSMateusz Kozlowski 
24195be29eSMateusz Kozlowski static void
free_rpc_construct_zone_block(struct rpc_construct_zone_block * req)25195be29eSMateusz Kozlowski free_rpc_construct_zone_block(struct rpc_construct_zone_block *req)
26195be29eSMateusz Kozlowski {
27195be29eSMateusz Kozlowski 	free(req->name);
28195be29eSMateusz Kozlowski 	free(req->base_bdev);
29195be29eSMateusz Kozlowski }
30195be29eSMateusz Kozlowski 
31195be29eSMateusz Kozlowski static const struct spdk_json_object_decoder rpc_construct_zone_block_decoders[] = {
32195be29eSMateusz Kozlowski 	{"name", offsetof(struct rpc_construct_zone_block, name), spdk_json_decode_string},
33195be29eSMateusz Kozlowski 	{"base_bdev", offsetof(struct rpc_construct_zone_block, base_bdev), spdk_json_decode_string},
34195be29eSMateusz Kozlowski 	{"zone_capacity", offsetof(struct rpc_construct_zone_block, zone_capacity), spdk_json_decode_uint64},
35195be29eSMateusz Kozlowski 	{"optimal_open_zones", offsetof(struct rpc_construct_zone_block, optimal_open_zones), spdk_json_decode_uint64},
36195be29eSMateusz Kozlowski };
37195be29eSMateusz Kozlowski 
38195be29eSMateusz Kozlowski static void
rpc_zone_block_create(struct spdk_jsonrpc_request * request,const struct spdk_json_val * params)39195be29eSMateusz Kozlowski rpc_zone_block_create(struct spdk_jsonrpc_request *request,
40195be29eSMateusz Kozlowski 		      const struct spdk_json_val *params)
41195be29eSMateusz Kozlowski {
42195be29eSMateusz Kozlowski 	struct rpc_construct_zone_block req = {};
43195be29eSMateusz Kozlowski 	struct spdk_json_write_ctx *w;
44195be29eSMateusz Kozlowski 	int rc;
45195be29eSMateusz Kozlowski 
46195be29eSMateusz Kozlowski 	if (spdk_json_decode_object(params, rpc_construct_zone_block_decoders,
47195be29eSMateusz Kozlowski 				    SPDK_COUNTOF(rpc_construct_zone_block_decoders),
48195be29eSMateusz Kozlowski 				    &req)) {
49195be29eSMateusz Kozlowski 		SPDK_ERRLOG("Failed to decode block create parameters");
50195be29eSMateusz Kozlowski 		spdk_jsonrpc_send_error_response(request, SPDK_JSONRPC_ERROR_INVALID_PARAMS,
51195be29eSMateusz Kozlowski 						 "Invalid parameters");
52195be29eSMateusz Kozlowski 		goto cleanup;
53195be29eSMateusz Kozlowski 	}
54195be29eSMateusz Kozlowski 
55a5e56dd3SSeth Howell 	rc = vbdev_zone_block_create(req.base_bdev, req.name, req.zone_capacity,
56195be29eSMateusz Kozlowski 				     req.optimal_open_zones);
57195be29eSMateusz Kozlowski 	if (rc) {
58195be29eSMateusz Kozlowski 		SPDK_ERRLOG("Failed to create block zoned vbdev: %s", spdk_strerror(-rc));
59195be29eSMateusz Kozlowski 		spdk_jsonrpc_send_error_response_fmt(request, SPDK_JSONRPC_ERROR_INTERNAL_ERROR,
60195be29eSMateusz Kozlowski 						     "Failed to create block zoned vbdev: %s",
61195be29eSMateusz Kozlowski 						     spdk_strerror(-rc));
62195be29eSMateusz Kozlowski 		goto cleanup;
63195be29eSMateusz Kozlowski 	}
64195be29eSMateusz Kozlowski 
65195be29eSMateusz Kozlowski 	w = spdk_jsonrpc_begin_result(request);
66195be29eSMateusz Kozlowski 	spdk_json_write_string(w, req.name);
67195be29eSMateusz Kozlowski 	spdk_jsonrpc_end_result(request, w);
68195be29eSMateusz Kozlowski 
69195be29eSMateusz Kozlowski cleanup:
70195be29eSMateusz Kozlowski 	free_rpc_construct_zone_block(&req);
71195be29eSMateusz Kozlowski }
72195be29eSMateusz Kozlowski SPDK_RPC_REGISTER("bdev_zone_block_create", rpc_zone_block_create, SPDK_RPC_RUNTIME)
73195be29eSMateusz Kozlowski 
74195be29eSMateusz Kozlowski struct rpc_delete_zone_block {
75195be29eSMateusz Kozlowski 	char *name;
76195be29eSMateusz Kozlowski };
77195be29eSMateusz Kozlowski 
78195be29eSMateusz Kozlowski static void
free_rpc_delete_zone_block(struct rpc_delete_zone_block * req)79195be29eSMateusz Kozlowski free_rpc_delete_zone_block(struct rpc_delete_zone_block *req)
80195be29eSMateusz Kozlowski {
81195be29eSMateusz Kozlowski 	free(req->name);
82195be29eSMateusz Kozlowski }
83195be29eSMateusz Kozlowski 
84195be29eSMateusz Kozlowski static const struct spdk_json_object_decoder rpc_delete_zone_block_decoders[] = {
85195be29eSMateusz Kozlowski 	{"name", offsetof(struct rpc_delete_zone_block, name), spdk_json_decode_string},
86195be29eSMateusz Kozlowski };
87195be29eSMateusz Kozlowski 
88195be29eSMateusz Kozlowski static void
_rpc_delete_zone_block_cb(void * cb_ctx,int rc)89195be29eSMateusz Kozlowski _rpc_delete_zone_block_cb(void *cb_ctx, int rc)
90195be29eSMateusz Kozlowski {
91195be29eSMateusz Kozlowski 	struct spdk_jsonrpc_request *request = cb_ctx;
92195be29eSMateusz Kozlowski 
93*c77bc554SShuhei Matsumoto 	if (rc == 0) {
94*c77bc554SShuhei Matsumoto 		spdk_jsonrpc_send_bool_response(request, true);
95*c77bc554SShuhei Matsumoto 	} else {
96*c77bc554SShuhei Matsumoto 		spdk_jsonrpc_send_error_response(request, rc, spdk_strerror(-rc));
97*c77bc554SShuhei Matsumoto 	}
98195be29eSMateusz Kozlowski }
99195be29eSMateusz Kozlowski 
100195be29eSMateusz Kozlowski static void
rpc_zone_block_delete(struct spdk_jsonrpc_request * request,const struct spdk_json_val * params)101195be29eSMateusz Kozlowski rpc_zone_block_delete(struct spdk_jsonrpc_request *request,
102195be29eSMateusz Kozlowski 		      const struct spdk_json_val *params)
103195be29eSMateusz Kozlowski {
104195be29eSMateusz Kozlowski 	struct rpc_delete_zone_block attrs = {};
105195be29eSMateusz Kozlowski 
106195be29eSMateusz Kozlowski 	if (spdk_json_decode_object(params, rpc_delete_zone_block_decoders,
107195be29eSMateusz Kozlowski 				    SPDK_COUNTOF(rpc_delete_zone_block_decoders),
108195be29eSMateusz Kozlowski 				    &attrs)) {
109195be29eSMateusz Kozlowski 		SPDK_ERRLOG("Failed to decode block delete parameters");
110195be29eSMateusz Kozlowski 		spdk_jsonrpc_send_error_response(request, SPDK_JSONRPC_ERROR_INVALID_PARAMS,
111195be29eSMateusz Kozlowski 						 "Invalid parameters");
112195be29eSMateusz Kozlowski 		goto cleanup;
113195be29eSMateusz Kozlowski 	}
114195be29eSMateusz Kozlowski 
115a5e56dd3SSeth Howell 	vbdev_zone_block_delete(attrs.name, _rpc_delete_zone_block_cb, request);
116195be29eSMateusz Kozlowski 
117195be29eSMateusz Kozlowski cleanup:
118195be29eSMateusz Kozlowski 	free_rpc_delete_zone_block(&attrs);
119195be29eSMateusz Kozlowski }
120195be29eSMateusz Kozlowski SPDK_RPC_REGISTER("bdev_zone_block_delete", rpc_zone_block_delete, SPDK_RPC_RUNTIME)
121