Latchesar Ionkov | bd238fb | 2007-07-10 17:57:28 -0500 | [diff] [blame] | 1 | /* |
| 2 | * include/net/9p/transport.h |
| 3 | * |
| 4 | * Transport Definition |
| 5 | * |
| 6 | * Copyright (C) 2005 by Latchesar Ionkov <lucho@ionkov.net> |
Eric Van Hensbergen | 8a0dc95 | 2008-02-06 19:25:03 -0600 | [diff] [blame] | 7 | * Copyright (C) 2004-2008 by Eric Van Hensbergen <ericvh@gmail.com> |
Latchesar Ionkov | bd238fb | 2007-07-10 17:57:28 -0500 | [diff] [blame] | 8 | * |
| 9 | * This program is free software; you can redistribute it and/or modify |
| 10 | * it under the terms of the GNU General Public License version 2 |
| 11 | * as published by the Free Software Foundation. |
| 12 | * |
| 13 | * This program is distributed in the hope that it will be useful, |
| 14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 16 | * GNU General Public License for more details. |
| 17 | * |
| 18 | * You should have received a copy of the GNU General Public License |
| 19 | * along with this program; if not, write to: |
| 20 | * Free Software Foundation |
| 21 | * 51 Franklin Street, Fifth Floor |
| 22 | * Boston, MA 02111-1301 USA |
| 23 | * |
| 24 | */ |
| 25 | |
| 26 | #ifndef NET_9P_TRANSPORT_H |
| 27 | #define NET_9P_TRANSPORT_H |
| 28 | |
Jim Garlick | 2f28c8b | 2013-05-29 12:15:07 -0700 | [diff] [blame] | 29 | #define P9_DEF_MIN_RESVPORT (665U) |
| 30 | #define P9_DEF_MAX_RESVPORT (1023U) |
| 31 | |
Eric Van Hensbergen | ee44399 | 2008-03-05 07:08:09 -0600 | [diff] [blame] | 32 | /** |
| 33 | * struct p9_trans_module - transport module interface |
| 34 | * @list: used to maintain a list of currently available transports |
| 35 | * @name: the human-readable name of the transport |
| 36 | * @maxsize: transport provided maximum packet size |
Venkateswararao Jujjuri (JV) | 6f69c39 | 2011-02-06 12:08:01 -0800 | [diff] [blame] | 37 | * @pref: Preferences of this transport |
Eric Van Hensbergen | ee44399 | 2008-03-05 07:08:09 -0600 | [diff] [blame] | 38 | * @def: set if this transport should be considered the default |
| 39 | * @create: member function to create a new connection on this transport |
Rob Landley | aca0076 | 2011-05-08 18:46:38 +0000 | [diff] [blame] | 40 | * @close: member function to discard a connection on this transport |
Eric Van Hensbergen | 91b8534 | 2008-10-13 18:45:21 -0500 | [diff] [blame] | 41 | * @request: member function to issue a request to the transport |
| 42 | * @cancel: member function to cancel a request (if it hasn't been sent) |
Simon Derr | afd8d65 | 2014-03-10 16:38:49 +0100 | [diff] [blame^] | 43 | * @cancelled: member function to notify that a cancelled request will not |
| 44 | * not receive a reply |
Eric Van Hensbergen | ee44399 | 2008-03-05 07:08:09 -0600 | [diff] [blame] | 45 | * |
| 46 | * This is the basic API for a transport module which is registered by the |
| 47 | * transport module with the 9P core network module and used by the client |
| 48 | * to instantiate a new connection on a transport. |
| 49 | * |
Rob Landley | aca0076 | 2011-05-08 18:46:38 +0000 | [diff] [blame] | 50 | * The transport module list is protected by v9fs_trans_lock. |
Eric Van Hensbergen | ee44399 | 2008-03-05 07:08:09 -0600 | [diff] [blame] | 51 | */ |
| 52 | |
Eric Van Hensbergen | a80d923 | 2007-10-17 14:31:07 -0500 | [diff] [blame] | 53 | struct p9_trans_module { |
| 54 | struct list_head list; |
| 55 | char *name; /* name of transport */ |
| 56 | int maxsize; /* max message size of transport */ |
| 57 | int def; /* this transport should be default */ |
Tejun Heo | 72029fe | 2008-09-24 16:22:23 -0500 | [diff] [blame] | 58 | struct module *owner; |
Eric Van Hensbergen | 8b81ef5 | 2008-10-13 18:45:25 -0500 | [diff] [blame] | 59 | int (*create)(struct p9_client *, const char *, char *); |
| 60 | void (*close) (struct p9_client *); |
Eric Van Hensbergen | 91b8534 | 2008-10-13 18:45:21 -0500 | [diff] [blame] | 61 | int (*request) (struct p9_client *, struct p9_req_t *req); |
| 62 | int (*cancel) (struct p9_client *, struct p9_req_t *req); |
Simon Derr | afd8d65 | 2014-03-10 16:38:49 +0100 | [diff] [blame^] | 63 | int (*cancelled)(struct p9_client *, struct p9_req_t *req); |
Aneesh Kumar K.V | abfa034 | 2011-08-16 10:50:10 +0530 | [diff] [blame] | 64 | int (*zc_request)(struct p9_client *, struct p9_req_t *, |
| 65 | char *, char *, int , int, int, int); |
Eric Van Hensbergen | a80d923 | 2007-10-17 14:31:07 -0500 | [diff] [blame] | 66 | }; |
| 67 | |
| 68 | void v9fs_register_trans(struct p9_trans_module *m); |
Tejun Heo | 72029fe | 2008-09-24 16:22:23 -0500 | [diff] [blame] | 69 | void v9fs_unregister_trans(struct p9_trans_module *m); |
Prem Karat | 4d63055 | 2011-05-06 18:35:32 +0530 | [diff] [blame] | 70 | struct p9_trans_module *v9fs_get_trans_by_name(char *s); |
Tejun Heo | 72029fe | 2008-09-24 16:22:23 -0500 | [diff] [blame] | 71 | struct p9_trans_module *v9fs_get_default_trans(void); |
| 72 | void v9fs_put_trans(struct p9_trans_module *m); |
Latchesar Ionkov | bd238fb | 2007-07-10 17:57:28 -0500 | [diff] [blame] | 73 | #endif /* NET_9P_TRANSPORT_H */ |