Motr  M0
rpc_internal.h
Go to the documentation of this file.
1 /* -*- C -*- */
2 /*
3  * Copyright (c) 2012-2020 Seagate Technology LLC and/or its Affiliates
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * For any questions about this software or licensing,
18  * please email opensource@seagate.com or cortx-questions@seagate.com.
19  *
20  */
21 
22 
23 #pragma once
24 
25 #ifndef __MOTR_RPC_INT_H__
26 #define __MOTR_RPC_INT_H__
27 
28 #include "rpc/conn_internal.h"
29 #include "rpc/session_internal.h"
30 #include "rpc/item_internal.h"
33 #include "rpc/packet_internal.h"
34 #include "rpc/session_fops_xc.h"
35 #include "rpc/session_fops.h"
36 #include "rpc/session_foms.h"
37 #include "rpc/onwire.h"
38 #include "rpc/onwire_xc.h"
39 #include "rpc/rpc.h"
40 
49 M0_INTERNAL int m0_rpc_session_module_init(void);
50 
54 M0_INTERNAL void m0_rpc_session_module_fini(void);
55 
59 M0_INTERNAL void rpc_worker_thread_fn(struct m0_rpc_machine *machine);
60 
65 M0_INTERNAL int m0_rpc__fop_post(struct m0_fop *fop,
66  struct m0_rpc_session *session,
67  const struct m0_rpc_item_ops *ops,
68  m0_time_t abs_timeout);
69 
73 M0_INTERNAL int m0_rpc__post_locked(struct m0_rpc_item *item);
74 
79 M0_INTERNAL int m0_rpc_item_dispatch(struct m0_rpc_item *item);
80 
81 M0_INTERNAL void m0_rpc_oneway_item_post_locked(const struct m0_rpc_conn *conn,
82  struct m0_rpc_item *item);
87 M0_INTERNAL uint64_t m0_rpc_id_generate(const struct m0_fid *uniq_fid);
88 
89 M0_INTERNAL int m0_rpc_service_start(struct m0_reqh *reqh);
90 M0_INTERNAL void m0_rpc_service_stop(struct m0_reqh *reqh);
91 
92 M0_TL_DESCR_DECLARE(item_source, M0_EXTERN);
93 M0_TL_DECLARE(item_source, M0_INTERNAL, struct m0_rpc_item_source);
94 
95 static inline struct m0_rpc_conn *item2conn(const struct m0_rpc_item *item)
96 {
97  return item->ri_session->s_conn;
98 }
99 
102 #endif /* __MOTR_RPC_INT_H__ */
M0_TL_DESCR_DECLARE(item_source, M0_EXTERN)
M0_INTERNAL void m0_rpc_service_stop(struct m0_reqh *reqh)
Definition: service.c:300
uint64_t m0_time_t
Definition: time.h:37
static struct m0_rpc_session session
Definition: formation2.c:38
static struct m0_rpc_item * item
Definition: item.c:56
M0_INTERNAL uint64_t m0_rpc_id_generate(const struct m0_fid *uniq_fid)
Definition: session_utils.c:96
M0_INTERNAL void m0_rpc_session_module_fini(void)
Definition: session_utils.c:52
M0_INTERNAL int m0_rpc__fop_post(struct m0_fop *fop, struct m0_rpc_session *session, const struct m0_rpc_item_ops *ops, m0_time_t abs_timeout)
Definition: session_utils.c:62
Definition: reqh.h:94
struct m0_rpc_conn conn
Definition: fsync.c:96
struct m0_rpc_machine machine
Definition: mdstore.c:58
M0_INTERNAL int m0_rpc_session_module_init(void)
Definition: session_utils.c:47
M0_TL_DECLARE(item_source, M0_INTERNAL, struct m0_rpc_item_source)
struct m0_reqh reqh
Definition: rm_foms.c:48
Definition: fid.h:38
M0_INTERNAL int m0_rpc_service_start(struct m0_reqh *reqh)
Definition: service.c:292
struct m0_rpc_session * ri_session
Definition: item.h:147
static struct m0_fop * fop
Definition: item.c:57
M0_INTERNAL int m0_rpc_item_dispatch(struct m0_rpc_item *item)
M0_INTERNAL void rpc_worker_thread_fn(struct m0_rpc_machine *machine)
Definition: rpc_machine.c:379
M0_INTERNAL void m0_rpc_oneway_item_post_locked(const struct m0_rpc_conn *conn, struct m0_rpc_item *item)
Definition: rpc.c:184
struct m0_fom_ops ops
Definition: io_foms.c:623
M0_INTERNAL int m0_rpc__post_locked(struct m0_rpc_item *item)
Definition: rpc.c:83
struct m0_rpc_conn * s_conn
Definition: session.h:312
Definition: fop.h:79
static struct m0_rpc_conn * item2conn(const struct m0_rpc_item *item)
Definition: rpc_internal.h:95