91b8534fa8
This code moves the rpc function to the common client base, reorganizes the flush code to be more simple and stable, and makes the necessary adjustments to the underlying transports to adapt to the new structure. This reduces the overall amount of code duplication between the transports and should make adding new transports more straightforward. Signed-off-by: Eric Van Hensbergen <ericvh@gmail.com>
64 lines
2.4 KiB
C
64 lines
2.4 KiB
C
/*
|
|
* include/net/9p/transport.h
|
|
*
|
|
* Transport Definition
|
|
*
|
|
* Copyright (C) 2005 by Latchesar Ionkov <lucho@ionkov.net>
|
|
* Copyright (C) 2004-2008 by Eric Van Hensbergen <ericvh@gmail.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to:
|
|
* Free Software Foundation
|
|
* 51 Franklin Street, Fifth Floor
|
|
* Boston, MA 02111-1301 USA
|
|
*
|
|
*/
|
|
|
|
#ifndef NET_9P_TRANSPORT_H
|
|
#define NET_9P_TRANSPORT_H
|
|
|
|
/**
|
|
* struct p9_trans_module - transport module interface
|
|
* @list: used to maintain a list of currently available transports
|
|
* @name: the human-readable name of the transport
|
|
* @maxsize: transport provided maximum packet size
|
|
* @def: set if this transport should be considered the default
|
|
* @create: member function to create a new connection on this transport
|
|
* @request: member function to issue a request to the transport
|
|
* @cancel: member function to cancel a request (if it hasn't been sent)
|
|
*
|
|
* This is the basic API for a transport module which is registered by the
|
|
* transport module with the 9P core network module and used by the client
|
|
* to instantiate a new connection on a transport.
|
|
*
|
|
* BUGS: the transport module list isn't protected.
|
|
*/
|
|
|
|
struct p9_trans_module {
|
|
struct list_head list;
|
|
char *name; /* name of transport */
|
|
int maxsize; /* max message size of transport */
|
|
int def; /* this transport should be default */
|
|
struct module *owner;
|
|
int (*create)(struct p9_client *, const char *, char *);
|
|
void (*close) (struct p9_client *);
|
|
int (*request) (struct p9_client *, struct p9_req_t *req);
|
|
int (*cancel) (struct p9_client *, struct p9_req_t *req);
|
|
};
|
|
|
|
void v9fs_register_trans(struct p9_trans_module *m);
|
|
void v9fs_unregister_trans(struct p9_trans_module *m);
|
|
struct p9_trans_module *v9fs_get_trans_by_name(const substring_t *name);
|
|
struct p9_trans_module *v9fs_get_default_trans(void);
|
|
void v9fs_put_trans(struct p9_trans_module *m);
|
|
#endif /* NET_9P_TRANSPORT_H */
|