af_qrtr.c 30 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2015, Sony Mobile Communications Inc.
  4. * Copyright (c) 2013, The Linux Foundation. All rights reserved.
  5. */
  6. #include <linux/module.h>
  7. #include <linux/netlink.h>
  8. #include <linux/qrtr.h>
  9. #include <linux/termios.h> /* For TIOCINQ/OUTQ */
  10. #include <linux/spinlock.h>
  11. #include <linux/wait.h>
  12. #include <net/sock.h>
  13. #include "qrtr.h"
  14. #define QRTR_PROTO_VER_1 1
  15. #define QRTR_PROTO_VER_2 3
  16. /* auto-bind range */
  17. #define QRTR_MIN_EPH_SOCKET 0x4000
  18. #define QRTR_MAX_EPH_SOCKET 0x7fff
  19. #define QRTR_EPH_PORT_RANGE \
  20. XA_LIMIT(QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET)
  21. #define QRTR_PORT_CTRL_LEGACY 0xffff
  22. /**
  23. * struct qrtr_hdr_v1 - (I|R)PCrouter packet header version 1
  24. * @version: protocol version
  25. * @type: packet type; one of QRTR_TYPE_*
  26. * @src_node_id: source node
  27. * @src_port_id: source port
  28. * @confirm_rx: boolean; whether a resume-tx packet should be send in reply
  29. * @size: length of packet, excluding this header
  30. * @dst_node_id: destination node
  31. * @dst_port_id: destination port
  32. */
  33. struct qrtr_hdr_v1 {
  34. __le32 version;
  35. __le32 type;
  36. __le32 src_node_id;
  37. __le32 src_port_id;
  38. __le32 confirm_rx;
  39. __le32 size;
  40. __le32 dst_node_id;
  41. __le32 dst_port_id;
  42. } __packed;
  43. /**
  44. * struct qrtr_hdr_v2 - (I|R)PCrouter packet header later versions
  45. * @version: protocol version
  46. * @type: packet type; one of QRTR_TYPE_*
  47. * @flags: bitmask of QRTR_FLAGS_*
  48. * @optlen: length of optional header data
  49. * @size: length of packet, excluding this header and optlen
  50. * @src_node_id: source node
  51. * @src_port_id: source port
  52. * @dst_node_id: destination node
  53. * @dst_port_id: destination port
  54. */
  55. struct qrtr_hdr_v2 {
  56. u8 version;
  57. u8 type;
  58. u8 flags;
  59. u8 optlen;
  60. __le32 size;
  61. __le16 src_node_id;
  62. __le16 src_port_id;
  63. __le16 dst_node_id;
  64. __le16 dst_port_id;
  65. };
  66. #define QRTR_FLAGS_CONFIRM_RX BIT(0)
  67. struct qrtr_cb {
  68. u32 src_node;
  69. u32 src_port;
  70. u32 dst_node;
  71. u32 dst_port;
  72. u8 type;
  73. u8 confirm_rx;
  74. };
  75. #define QRTR_HDR_MAX_SIZE max_t(size_t, sizeof(struct qrtr_hdr_v1), \
  76. sizeof(struct qrtr_hdr_v2))
  77. struct qrtr_sock {
  78. /* WARNING: sk must be the first member */
  79. struct sock sk;
  80. struct sockaddr_qrtr us;
  81. struct sockaddr_qrtr peer;
  82. };
  83. static inline struct qrtr_sock *qrtr_sk(struct sock *sk)
  84. {
  85. BUILD_BUG_ON(offsetof(struct qrtr_sock, sk) != 0);
  86. return container_of(sk, struct qrtr_sock, sk);
  87. }
  88. static unsigned int qrtr_local_nid = 1;
  89. /* for node ids */
  90. static RADIX_TREE(qrtr_nodes, GFP_ATOMIC);
  91. static DEFINE_SPINLOCK(qrtr_nodes_lock);
  92. /* broadcast list */
  93. static LIST_HEAD(qrtr_all_nodes);
  94. /* lock for qrtr_all_nodes and node reference */
  95. static DEFINE_MUTEX(qrtr_node_lock);
  96. /* local port allocation management */
  97. static DEFINE_XARRAY_ALLOC(qrtr_ports);
  98. /**
  99. * struct qrtr_node - endpoint node
  100. * @ep_lock: lock for endpoint management and callbacks
  101. * @ep: endpoint
  102. * @ref: reference count for node
  103. * @nid: node id
  104. * @qrtr_tx_flow: tree of qrtr_tx_flow, keyed by node << 32 | port
  105. * @qrtr_tx_lock: lock for qrtr_tx_flow inserts
  106. * @rx_queue: receive queue
  107. * @item: list item for broadcast list
  108. */
  109. struct qrtr_node {
  110. struct mutex ep_lock;
  111. struct qrtr_endpoint *ep;
  112. struct kref ref;
  113. unsigned int nid;
  114. struct radix_tree_root qrtr_tx_flow;
  115. struct mutex qrtr_tx_lock; /* for qrtr_tx_flow */
  116. struct sk_buff_head rx_queue;
  117. struct list_head item;
  118. };
  119. /**
  120. * struct qrtr_tx_flow - tx flow control
  121. * @resume_tx: waiters for a resume tx from the remote
  122. * @pending: number of waiting senders
  123. * @tx_failed: indicates that a message with confirm_rx flag was lost
  124. */
  125. struct qrtr_tx_flow {
  126. struct wait_queue_head resume_tx;
  127. int pending;
  128. int tx_failed;
  129. };
  130. #define QRTR_TX_FLOW_HIGH 10
  131. #define QRTR_TX_FLOW_LOW 5
  132. static int qrtr_local_enqueue(struct qrtr_node *node, struct sk_buff *skb,
  133. int type, struct sockaddr_qrtr *from,
  134. struct sockaddr_qrtr *to);
  135. static int qrtr_bcast_enqueue(struct qrtr_node *node, struct sk_buff *skb,
  136. int type, struct sockaddr_qrtr *from,
  137. struct sockaddr_qrtr *to);
  138. static struct qrtr_sock *qrtr_port_lookup(int port);
  139. static void qrtr_port_put(struct qrtr_sock *ipc);
  140. /* Release node resources and free the node.
  141. *
  142. * Do not call directly, use qrtr_node_release. To be used with
  143. * kref_put_mutex. As such, the node mutex is expected to be locked on call.
  144. */
  145. static void __qrtr_node_release(struct kref *kref)
  146. {
  147. struct qrtr_node *node = container_of(kref, struct qrtr_node, ref);
  148. struct radix_tree_iter iter;
  149. struct qrtr_tx_flow *flow;
  150. unsigned long flags;
  151. void __rcu **slot;
  152. spin_lock_irqsave(&qrtr_nodes_lock, flags);
  153. /* If the node is a bridge for other nodes, there are possibly
  154. * multiple entries pointing to our released node, delete them all.
  155. */
  156. radix_tree_for_each_slot(slot, &qrtr_nodes, &iter, 0) {
  157. if (*slot == node)
  158. radix_tree_iter_delete(&qrtr_nodes, &iter, slot);
  159. }
  160. spin_unlock_irqrestore(&qrtr_nodes_lock, flags);
  161. list_del(&node->item);
  162. mutex_unlock(&qrtr_node_lock);
  163. skb_queue_purge(&node->rx_queue);
  164. /* Free tx flow counters */
  165. radix_tree_for_each_slot(slot, &node->qrtr_tx_flow, &iter, 0) {
  166. flow = *slot;
  167. radix_tree_iter_delete(&node->qrtr_tx_flow, &iter, slot);
  168. kfree(flow);
  169. }
  170. kfree(node);
  171. }
  172. /* Increment reference to node. */
  173. static struct qrtr_node *qrtr_node_acquire(struct qrtr_node *node)
  174. {
  175. if (node)
  176. kref_get(&node->ref);
  177. return node;
  178. }
  179. /* Decrement reference to node and release as necessary. */
  180. static void qrtr_node_release(struct qrtr_node *node)
  181. {
  182. if (!node)
  183. return;
  184. kref_put_mutex(&node->ref, __qrtr_node_release, &qrtr_node_lock);
  185. }
  186. /**
  187. * qrtr_tx_resume() - reset flow control counter
  188. * @node: qrtr_node that the QRTR_TYPE_RESUME_TX packet arrived on
  189. * @skb: resume_tx packet
  190. */
  191. static void qrtr_tx_resume(struct qrtr_node *node, struct sk_buff *skb)
  192. {
  193. struct qrtr_ctrl_pkt *pkt = (struct qrtr_ctrl_pkt *)skb->data;
  194. u64 remote_node = le32_to_cpu(pkt->client.node);
  195. u32 remote_port = le32_to_cpu(pkt->client.port);
  196. struct qrtr_tx_flow *flow;
  197. unsigned long key;
  198. key = remote_node << 32 | remote_port;
  199. rcu_read_lock();
  200. flow = radix_tree_lookup(&node->qrtr_tx_flow, key);
  201. rcu_read_unlock();
  202. if (flow) {
  203. spin_lock(&flow->resume_tx.lock);
  204. flow->pending = 0;
  205. spin_unlock(&flow->resume_tx.lock);
  206. wake_up_interruptible_all(&flow->resume_tx);
  207. }
  208. consume_skb(skb);
  209. }
  210. /**
  211. * qrtr_tx_wait() - flow control for outgoing packets
  212. * @node: qrtr_node that the packet is to be send to
  213. * @dest_node: node id of the destination
  214. * @dest_port: port number of the destination
  215. * @type: type of message
  216. *
  217. * The flow control scheme is based around the low and high "watermarks". When
  218. * the low watermark is passed the confirm_rx flag is set on the outgoing
  219. * message, which will trigger the remote to send a control message of the type
  220. * QRTR_TYPE_RESUME_TX to reset the counter. If the high watermark is hit
  221. * further transmision should be paused.
  222. *
  223. * Return: 1 if confirm_rx should be set, 0 otherwise or errno failure
  224. */
  225. static int qrtr_tx_wait(struct qrtr_node *node, int dest_node, int dest_port,
  226. int type)
  227. {
  228. unsigned long key = (u64)dest_node << 32 | dest_port;
  229. struct qrtr_tx_flow *flow;
  230. int confirm_rx = 0;
  231. int ret;
  232. /* Never set confirm_rx on non-data packets */
  233. if (type != QRTR_TYPE_DATA)
  234. return 0;
  235. mutex_lock(&node->qrtr_tx_lock);
  236. flow = radix_tree_lookup(&node->qrtr_tx_flow, key);
  237. if (!flow) {
  238. flow = kzalloc(sizeof(*flow), GFP_KERNEL);
  239. if (flow) {
  240. init_waitqueue_head(&flow->resume_tx);
  241. if (radix_tree_insert(&node->qrtr_tx_flow, key, flow)) {
  242. kfree(flow);
  243. flow = NULL;
  244. }
  245. }
  246. }
  247. mutex_unlock(&node->qrtr_tx_lock);
  248. /* Set confirm_rx if we where unable to find and allocate a flow */
  249. if (!flow)
  250. return 1;
  251. spin_lock_irq(&flow->resume_tx.lock);
  252. ret = wait_event_interruptible_locked_irq(flow->resume_tx,
  253. flow->pending < QRTR_TX_FLOW_HIGH ||
  254. flow->tx_failed ||
  255. !node->ep);
  256. if (ret < 0) {
  257. confirm_rx = ret;
  258. } else if (!node->ep) {
  259. confirm_rx = -EPIPE;
  260. } else if (flow->tx_failed) {
  261. flow->tx_failed = 0;
  262. confirm_rx = 1;
  263. } else {
  264. flow->pending++;
  265. confirm_rx = flow->pending == QRTR_TX_FLOW_LOW;
  266. }
  267. spin_unlock_irq(&flow->resume_tx.lock);
  268. return confirm_rx;
  269. }
  270. /**
  271. * qrtr_tx_flow_failed() - flag that tx of confirm_rx flagged messages failed
  272. * @node: qrtr_node that the packet is to be send to
  273. * @dest_node: node id of the destination
  274. * @dest_port: port number of the destination
  275. *
  276. * Signal that the transmission of a message with confirm_rx flag failed. The
  277. * flow's "pending" counter will keep incrementing towards QRTR_TX_FLOW_HIGH,
  278. * at which point transmission would stall forever waiting for the resume TX
  279. * message associated with the dropped confirm_rx message.
  280. * Work around this by marking the flow as having a failed transmission and
  281. * cause the next transmission attempt to be sent with the confirm_rx.
  282. */
  283. static void qrtr_tx_flow_failed(struct qrtr_node *node, int dest_node,
  284. int dest_port)
  285. {
  286. unsigned long key = (u64)dest_node << 32 | dest_port;
  287. struct qrtr_tx_flow *flow;
  288. rcu_read_lock();
  289. flow = radix_tree_lookup(&node->qrtr_tx_flow, key);
  290. rcu_read_unlock();
  291. if (flow) {
  292. spin_lock_irq(&flow->resume_tx.lock);
  293. flow->tx_failed = 1;
  294. spin_unlock_irq(&flow->resume_tx.lock);
  295. }
  296. }
  297. /* Pass an outgoing packet socket buffer to the endpoint driver. */
  298. static int qrtr_node_enqueue(struct qrtr_node *node, struct sk_buff *skb,
  299. int type, struct sockaddr_qrtr *from,
  300. struct sockaddr_qrtr *to)
  301. {
  302. struct qrtr_hdr_v1 *hdr;
  303. size_t len = skb->len;
  304. int rc, confirm_rx;
  305. confirm_rx = qrtr_tx_wait(node, to->sq_node, to->sq_port, type);
  306. if (confirm_rx < 0) {
  307. kfree_skb(skb);
  308. return confirm_rx;
  309. }
  310. hdr = skb_push(skb, sizeof(*hdr));
  311. hdr->version = cpu_to_le32(QRTR_PROTO_VER_1);
  312. hdr->type = cpu_to_le32(type);
  313. hdr->src_node_id = cpu_to_le32(from->sq_node);
  314. hdr->src_port_id = cpu_to_le32(from->sq_port);
  315. if (to->sq_port == QRTR_PORT_CTRL) {
  316. hdr->dst_node_id = cpu_to_le32(node->nid);
  317. hdr->dst_port_id = cpu_to_le32(QRTR_PORT_CTRL);
  318. } else {
  319. hdr->dst_node_id = cpu_to_le32(to->sq_node);
  320. hdr->dst_port_id = cpu_to_le32(to->sq_port);
  321. }
  322. hdr->size = cpu_to_le32(len);
  323. hdr->confirm_rx = !!confirm_rx;
  324. rc = skb_put_padto(skb, ALIGN(len, 4) + sizeof(*hdr));
  325. if (!rc) {
  326. mutex_lock(&node->ep_lock);
  327. rc = -ENODEV;
  328. if (node->ep)
  329. rc = node->ep->xmit(node->ep, skb);
  330. else
  331. kfree_skb(skb);
  332. mutex_unlock(&node->ep_lock);
  333. }
  334. /* Need to ensure that a subsequent message carries the otherwise lost
  335. * confirm_rx flag if we dropped this one */
  336. if (rc && confirm_rx)
  337. qrtr_tx_flow_failed(node, to->sq_node, to->sq_port);
  338. return rc;
  339. }
  340. /* Lookup node by id.
  341. *
  342. * callers must release with qrtr_node_release()
  343. */
  344. static struct qrtr_node *qrtr_node_lookup(unsigned int nid)
  345. {
  346. struct qrtr_node *node;
  347. unsigned long flags;
  348. mutex_lock(&qrtr_node_lock);
  349. spin_lock_irqsave(&qrtr_nodes_lock, flags);
  350. node = radix_tree_lookup(&qrtr_nodes, nid);
  351. node = qrtr_node_acquire(node);
  352. spin_unlock_irqrestore(&qrtr_nodes_lock, flags);
  353. mutex_unlock(&qrtr_node_lock);
  354. return node;
  355. }
  356. /* Assign node id to node.
  357. *
  358. * This is mostly useful for automatic node id assignment, based on
  359. * the source id in the incoming packet.
  360. */
  361. static void qrtr_node_assign(struct qrtr_node *node, unsigned int nid)
  362. {
  363. unsigned long flags;
  364. if (nid == QRTR_EP_NID_AUTO)
  365. return;
  366. spin_lock_irqsave(&qrtr_nodes_lock, flags);
  367. radix_tree_insert(&qrtr_nodes, nid, node);
  368. if (node->nid == QRTR_EP_NID_AUTO)
  369. node->nid = nid;
  370. spin_unlock_irqrestore(&qrtr_nodes_lock, flags);
  371. }
  372. /**
  373. * qrtr_endpoint_post() - post incoming data
  374. * @ep: endpoint handle
  375. * @data: data pointer
  376. * @len: size of data in bytes
  377. *
  378. * Return: 0 on success; negative error code on failure
  379. */
  380. int qrtr_endpoint_post(struct qrtr_endpoint *ep, const void *data, size_t len)
  381. {
  382. struct qrtr_node *node = ep->node;
  383. const struct qrtr_hdr_v1 *v1;
  384. const struct qrtr_hdr_v2 *v2;
  385. struct qrtr_sock *ipc;
  386. struct sk_buff *skb;
  387. struct qrtr_cb *cb;
  388. size_t size;
  389. unsigned int ver;
  390. size_t hdrlen;
  391. if (len == 0 || len & 3)
  392. return -EINVAL;
  393. skb = __netdev_alloc_skb(NULL, len, GFP_ATOMIC | __GFP_NOWARN);
  394. if (!skb)
  395. return -ENOMEM;
  396. cb = (struct qrtr_cb *)skb->cb;
  397. /* Version field in v1 is little endian, so this works for both cases */
  398. ver = *(u8*)data;
  399. switch (ver) {
  400. case QRTR_PROTO_VER_1:
  401. if (len < sizeof(*v1))
  402. goto err;
  403. v1 = data;
  404. hdrlen = sizeof(*v1);
  405. cb->type = le32_to_cpu(v1->type);
  406. cb->src_node = le32_to_cpu(v1->src_node_id);
  407. cb->src_port = le32_to_cpu(v1->src_port_id);
  408. cb->confirm_rx = !!v1->confirm_rx;
  409. cb->dst_node = le32_to_cpu(v1->dst_node_id);
  410. cb->dst_port = le32_to_cpu(v1->dst_port_id);
  411. size = le32_to_cpu(v1->size);
  412. break;
  413. case QRTR_PROTO_VER_2:
  414. if (len < sizeof(*v2))
  415. goto err;
  416. v2 = data;
  417. hdrlen = sizeof(*v2) + v2->optlen;
  418. cb->type = v2->type;
  419. cb->confirm_rx = !!(v2->flags & QRTR_FLAGS_CONFIRM_RX);
  420. cb->src_node = le16_to_cpu(v2->src_node_id);
  421. cb->src_port = le16_to_cpu(v2->src_port_id);
  422. cb->dst_node = le16_to_cpu(v2->dst_node_id);
  423. cb->dst_port = le16_to_cpu(v2->dst_port_id);
  424. if (cb->src_port == (u16)QRTR_PORT_CTRL)
  425. cb->src_port = QRTR_PORT_CTRL;
  426. if (cb->dst_port == (u16)QRTR_PORT_CTRL)
  427. cb->dst_port = QRTR_PORT_CTRL;
  428. size = le32_to_cpu(v2->size);
  429. break;
  430. default:
  431. pr_err("qrtr: Invalid version %d\n", ver);
  432. goto err;
  433. }
  434. if (cb->dst_port == QRTR_PORT_CTRL_LEGACY)
  435. cb->dst_port = QRTR_PORT_CTRL;
  436. if (!size || len != ALIGN(size, 4) + hdrlen)
  437. goto err;
  438. if ((cb->type == QRTR_TYPE_NEW_SERVER ||
  439. cb->type == QRTR_TYPE_RESUME_TX) &&
  440. size < sizeof(struct qrtr_ctrl_pkt))
  441. goto err;
  442. if (cb->dst_port != QRTR_PORT_CTRL && cb->type != QRTR_TYPE_DATA &&
  443. cb->type != QRTR_TYPE_RESUME_TX)
  444. goto err;
  445. skb_put_data(skb, data + hdrlen, size);
  446. qrtr_node_assign(node, cb->src_node);
  447. if (cb->type == QRTR_TYPE_NEW_SERVER) {
  448. /* Remote node endpoint can bridge other distant nodes */
  449. const struct qrtr_ctrl_pkt *pkt;
  450. pkt = data + hdrlen;
  451. qrtr_node_assign(node, le32_to_cpu(pkt->server.node));
  452. }
  453. if (cb->type == QRTR_TYPE_RESUME_TX) {
  454. qrtr_tx_resume(node, skb);
  455. } else {
  456. ipc = qrtr_port_lookup(cb->dst_port);
  457. if (!ipc)
  458. goto err;
  459. if (sock_queue_rcv_skb(&ipc->sk, skb)) {
  460. qrtr_port_put(ipc);
  461. goto err;
  462. }
  463. qrtr_port_put(ipc);
  464. }
  465. return 0;
  466. err:
  467. kfree_skb(skb);
  468. return -EINVAL;
  469. }
  470. EXPORT_SYMBOL_GPL(qrtr_endpoint_post);
  471. /**
  472. * qrtr_alloc_ctrl_packet() - allocate control packet skb
  473. * @pkt: reference to qrtr_ctrl_pkt pointer
  474. * @flags: the type of memory to allocate
  475. *
  476. * Returns newly allocated sk_buff, or NULL on failure
  477. *
  478. * This function allocates a sk_buff large enough to carry a qrtr_ctrl_pkt and
  479. * on success returns a reference to the control packet in @pkt.
  480. */
  481. static struct sk_buff *qrtr_alloc_ctrl_packet(struct qrtr_ctrl_pkt **pkt,
  482. gfp_t flags)
  483. {
  484. const int pkt_len = sizeof(struct qrtr_ctrl_pkt);
  485. struct sk_buff *skb;
  486. skb = alloc_skb(QRTR_HDR_MAX_SIZE + pkt_len, flags);
  487. if (!skb)
  488. return NULL;
  489. skb_reserve(skb, QRTR_HDR_MAX_SIZE);
  490. *pkt = skb_put_zero(skb, pkt_len);
  491. return skb;
  492. }
  493. /**
  494. * qrtr_endpoint_register() - register a new endpoint
  495. * @ep: endpoint to register
  496. * @nid: desired node id; may be QRTR_EP_NID_AUTO for auto-assignment
  497. * Return: 0 on success; negative error code on failure
  498. *
  499. * The specified endpoint must have the xmit function pointer set on call.
  500. */
  501. int qrtr_endpoint_register(struct qrtr_endpoint *ep, unsigned int nid)
  502. {
  503. struct qrtr_node *node;
  504. if (!ep || !ep->xmit)
  505. return -EINVAL;
  506. node = kzalloc(sizeof(*node), GFP_KERNEL);
  507. if (!node)
  508. return -ENOMEM;
  509. kref_init(&node->ref);
  510. mutex_init(&node->ep_lock);
  511. skb_queue_head_init(&node->rx_queue);
  512. node->nid = QRTR_EP_NID_AUTO;
  513. node->ep = ep;
  514. INIT_RADIX_TREE(&node->qrtr_tx_flow, GFP_KERNEL);
  515. mutex_init(&node->qrtr_tx_lock);
  516. qrtr_node_assign(node, nid);
  517. mutex_lock(&qrtr_node_lock);
  518. list_add(&node->item, &qrtr_all_nodes);
  519. mutex_unlock(&qrtr_node_lock);
  520. ep->node = node;
  521. return 0;
  522. }
  523. EXPORT_SYMBOL_GPL(qrtr_endpoint_register);
  524. /**
  525. * qrtr_endpoint_unregister - unregister endpoint
  526. * @ep: endpoint to unregister
  527. */
  528. void qrtr_endpoint_unregister(struct qrtr_endpoint *ep)
  529. {
  530. struct qrtr_node *node = ep->node;
  531. struct sockaddr_qrtr src = {AF_QIPCRTR, node->nid, QRTR_PORT_CTRL};
  532. struct sockaddr_qrtr dst = {AF_QIPCRTR, qrtr_local_nid, QRTR_PORT_CTRL};
  533. struct radix_tree_iter iter;
  534. struct qrtr_ctrl_pkt *pkt;
  535. struct qrtr_tx_flow *flow;
  536. struct sk_buff *skb;
  537. unsigned long flags;
  538. void __rcu **slot;
  539. mutex_lock(&node->ep_lock);
  540. node->ep = NULL;
  541. mutex_unlock(&node->ep_lock);
  542. /* Notify the local controller about the event */
  543. spin_lock_irqsave(&qrtr_nodes_lock, flags);
  544. radix_tree_for_each_slot(slot, &qrtr_nodes, &iter, 0) {
  545. if (*slot != node)
  546. continue;
  547. src.sq_node = iter.index;
  548. skb = qrtr_alloc_ctrl_packet(&pkt, GFP_ATOMIC);
  549. if (skb) {
  550. pkt->cmd = cpu_to_le32(QRTR_TYPE_BYE);
  551. qrtr_local_enqueue(NULL, skb, QRTR_TYPE_BYE, &src, &dst);
  552. }
  553. }
  554. spin_unlock_irqrestore(&qrtr_nodes_lock, flags);
  555. /* Wake up any transmitters waiting for resume-tx from the node */
  556. mutex_lock(&node->qrtr_tx_lock);
  557. radix_tree_for_each_slot(slot, &node->qrtr_tx_flow, &iter, 0) {
  558. flow = *slot;
  559. wake_up_interruptible_all(&flow->resume_tx);
  560. }
  561. mutex_unlock(&node->qrtr_tx_lock);
  562. qrtr_node_release(node);
  563. ep->node = NULL;
  564. }
  565. EXPORT_SYMBOL_GPL(qrtr_endpoint_unregister);
  566. /* Lookup socket by port.
  567. *
  568. * Callers must release with qrtr_port_put()
  569. */
  570. static struct qrtr_sock *qrtr_port_lookup(int port)
  571. {
  572. struct qrtr_sock *ipc;
  573. if (port == QRTR_PORT_CTRL)
  574. port = 0;
  575. rcu_read_lock();
  576. ipc = xa_load(&qrtr_ports, port);
  577. if (ipc)
  578. sock_hold(&ipc->sk);
  579. rcu_read_unlock();
  580. return ipc;
  581. }
  582. /* Release acquired socket. */
  583. static void qrtr_port_put(struct qrtr_sock *ipc)
  584. {
  585. sock_put(&ipc->sk);
  586. }
  587. /* Remove port assignment. */
  588. static void qrtr_port_remove(struct qrtr_sock *ipc)
  589. {
  590. struct qrtr_ctrl_pkt *pkt;
  591. struct sk_buff *skb;
  592. int port = ipc->us.sq_port;
  593. struct sockaddr_qrtr to;
  594. to.sq_family = AF_QIPCRTR;
  595. to.sq_node = QRTR_NODE_BCAST;
  596. to.sq_port = QRTR_PORT_CTRL;
  597. skb = qrtr_alloc_ctrl_packet(&pkt, GFP_KERNEL);
  598. if (skb) {
  599. pkt->cmd = cpu_to_le32(QRTR_TYPE_DEL_CLIENT);
  600. pkt->client.node = cpu_to_le32(ipc->us.sq_node);
  601. pkt->client.port = cpu_to_le32(ipc->us.sq_port);
  602. skb_set_owner_w(skb, &ipc->sk);
  603. qrtr_bcast_enqueue(NULL, skb, QRTR_TYPE_DEL_CLIENT, &ipc->us,
  604. &to);
  605. }
  606. if (port == QRTR_PORT_CTRL)
  607. port = 0;
  608. __sock_put(&ipc->sk);
  609. xa_erase(&qrtr_ports, port);
  610. /* Ensure that if qrtr_port_lookup() did enter the RCU read section we
  611. * wait for it to up increment the refcount */
  612. synchronize_rcu();
  613. }
  614. /* Assign port number to socket.
  615. *
  616. * Specify port in the integer pointed to by port, and it will be adjusted
  617. * on return as necesssary.
  618. *
  619. * Port may be:
  620. * 0: Assign ephemeral port in [QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET]
  621. * <QRTR_MIN_EPH_SOCKET: Specified; requires CAP_NET_ADMIN
  622. * >QRTR_MIN_EPH_SOCKET: Specified; available to all
  623. */
  624. static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)
  625. {
  626. int rc;
  627. if (!*port) {
  628. rc = xa_alloc(&qrtr_ports, port, ipc, QRTR_EPH_PORT_RANGE,
  629. GFP_KERNEL);
  630. } else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {
  631. rc = -EACCES;
  632. } else if (*port == QRTR_PORT_CTRL) {
  633. rc = xa_insert(&qrtr_ports, 0, ipc, GFP_KERNEL);
  634. } else {
  635. rc = xa_insert(&qrtr_ports, *port, ipc, GFP_KERNEL);
  636. }
  637. if (rc == -EBUSY)
  638. return -EADDRINUSE;
  639. else if (rc < 0)
  640. return rc;
  641. sock_hold(&ipc->sk);
  642. return 0;
  643. }
  644. /* Reset all non-control ports */
  645. static void qrtr_reset_ports(void)
  646. {
  647. struct qrtr_sock *ipc;
  648. unsigned long index;
  649. rcu_read_lock();
  650. xa_for_each_start(&qrtr_ports, index, ipc, 1) {
  651. sock_hold(&ipc->sk);
  652. ipc->sk.sk_err = ENETRESET;
  653. sk_error_report(&ipc->sk);
  654. sock_put(&ipc->sk);
  655. }
  656. rcu_read_unlock();
  657. }
  658. /* Bind socket to address.
  659. *
  660. * Socket should be locked upon call.
  661. */
  662. static int __qrtr_bind(struct socket *sock,
  663. const struct sockaddr_qrtr *addr, int zapped)
  664. {
  665. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  666. struct sock *sk = sock->sk;
  667. int port;
  668. int rc;
  669. /* rebinding ok */
  670. if (!zapped && addr->sq_port == ipc->us.sq_port)
  671. return 0;
  672. port = addr->sq_port;
  673. rc = qrtr_port_assign(ipc, &port);
  674. if (rc)
  675. return rc;
  676. /* unbind previous, if any */
  677. if (!zapped)
  678. qrtr_port_remove(ipc);
  679. ipc->us.sq_port = port;
  680. sock_reset_flag(sk, SOCK_ZAPPED);
  681. /* Notify all open ports about the new controller */
  682. if (port == QRTR_PORT_CTRL)
  683. qrtr_reset_ports();
  684. return 0;
  685. }
  686. /* Auto bind to an ephemeral port. */
  687. static int qrtr_autobind(struct socket *sock)
  688. {
  689. struct sock *sk = sock->sk;
  690. struct sockaddr_qrtr addr;
  691. if (!sock_flag(sk, SOCK_ZAPPED))
  692. return 0;
  693. addr.sq_family = AF_QIPCRTR;
  694. addr.sq_node = qrtr_local_nid;
  695. addr.sq_port = 0;
  696. return __qrtr_bind(sock, &addr, 1);
  697. }
  698. /* Bind socket to specified sockaddr. */
  699. static int qrtr_bind(struct socket *sock, struct sockaddr *saddr, int len)
  700. {
  701. DECLARE_SOCKADDR(struct sockaddr_qrtr *, addr, saddr);
  702. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  703. struct sock *sk = sock->sk;
  704. int rc;
  705. if (len < sizeof(*addr) || addr->sq_family != AF_QIPCRTR)
  706. return -EINVAL;
  707. if (addr->sq_node != ipc->us.sq_node)
  708. return -EINVAL;
  709. lock_sock(sk);
  710. rc = __qrtr_bind(sock, addr, sock_flag(sk, SOCK_ZAPPED));
  711. release_sock(sk);
  712. return rc;
  713. }
  714. /* Queue packet to local peer socket. */
  715. static int qrtr_local_enqueue(struct qrtr_node *node, struct sk_buff *skb,
  716. int type, struct sockaddr_qrtr *from,
  717. struct sockaddr_qrtr *to)
  718. {
  719. struct qrtr_sock *ipc;
  720. struct qrtr_cb *cb;
  721. ipc = qrtr_port_lookup(to->sq_port);
  722. if (!ipc || &ipc->sk == skb->sk) { /* do not send to self */
  723. if (ipc)
  724. qrtr_port_put(ipc);
  725. kfree_skb(skb);
  726. return -ENODEV;
  727. }
  728. cb = (struct qrtr_cb *)skb->cb;
  729. cb->src_node = from->sq_node;
  730. cb->src_port = from->sq_port;
  731. if (sock_queue_rcv_skb(&ipc->sk, skb)) {
  732. qrtr_port_put(ipc);
  733. kfree_skb(skb);
  734. return -ENOSPC;
  735. }
  736. qrtr_port_put(ipc);
  737. return 0;
  738. }
  739. /* Queue packet for broadcast. */
  740. static int qrtr_bcast_enqueue(struct qrtr_node *node, struct sk_buff *skb,
  741. int type, struct sockaddr_qrtr *from,
  742. struct sockaddr_qrtr *to)
  743. {
  744. struct sk_buff *skbn;
  745. mutex_lock(&qrtr_node_lock);
  746. list_for_each_entry(node, &qrtr_all_nodes, item) {
  747. skbn = pskb_copy(skb, GFP_KERNEL);
  748. if (!skbn)
  749. break;
  750. skb_set_owner_w(skbn, skb->sk);
  751. qrtr_node_enqueue(node, skbn, type, from, to);
  752. }
  753. mutex_unlock(&qrtr_node_lock);
  754. qrtr_local_enqueue(NULL, skb, type, from, to);
  755. return 0;
  756. }
  757. static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)
  758. {
  759. DECLARE_SOCKADDR(struct sockaddr_qrtr *, addr, msg->msg_name);
  760. int (*enqueue_fn)(struct qrtr_node *, struct sk_buff *, int,
  761. struct sockaddr_qrtr *, struct sockaddr_qrtr *);
  762. __le32 qrtr_type = cpu_to_le32(QRTR_TYPE_DATA);
  763. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  764. struct sock *sk = sock->sk;
  765. struct qrtr_node *node;
  766. struct sk_buff *skb;
  767. size_t plen;
  768. u32 type;
  769. int rc;
  770. if (msg->msg_flags & ~(MSG_DONTWAIT))
  771. return -EINVAL;
  772. if (len > 65535)
  773. return -EMSGSIZE;
  774. lock_sock(sk);
  775. if (addr) {
  776. if (msg->msg_namelen < sizeof(*addr)) {
  777. release_sock(sk);
  778. return -EINVAL;
  779. }
  780. if (addr->sq_family != AF_QIPCRTR) {
  781. release_sock(sk);
  782. return -EINVAL;
  783. }
  784. rc = qrtr_autobind(sock);
  785. if (rc) {
  786. release_sock(sk);
  787. return rc;
  788. }
  789. } else if (sk->sk_state == TCP_ESTABLISHED) {
  790. addr = &ipc->peer;
  791. } else {
  792. release_sock(sk);
  793. return -ENOTCONN;
  794. }
  795. node = NULL;
  796. if (addr->sq_node == QRTR_NODE_BCAST) {
  797. if (addr->sq_port != QRTR_PORT_CTRL &&
  798. qrtr_local_nid != QRTR_NODE_BCAST) {
  799. release_sock(sk);
  800. return -ENOTCONN;
  801. }
  802. enqueue_fn = qrtr_bcast_enqueue;
  803. } else if (addr->sq_node == ipc->us.sq_node) {
  804. enqueue_fn = qrtr_local_enqueue;
  805. } else {
  806. node = qrtr_node_lookup(addr->sq_node);
  807. if (!node) {
  808. release_sock(sk);
  809. return -ECONNRESET;
  810. }
  811. enqueue_fn = qrtr_node_enqueue;
  812. }
  813. plen = (len + 3) & ~3;
  814. skb = sock_alloc_send_skb(sk, plen + QRTR_HDR_MAX_SIZE,
  815. msg->msg_flags & MSG_DONTWAIT, &rc);
  816. if (!skb) {
  817. rc = -ENOMEM;
  818. goto out_node;
  819. }
  820. skb_reserve(skb, QRTR_HDR_MAX_SIZE);
  821. rc = memcpy_from_msg(skb_put(skb, len), msg, len);
  822. if (rc) {
  823. kfree_skb(skb);
  824. goto out_node;
  825. }
  826. if (ipc->us.sq_port == QRTR_PORT_CTRL) {
  827. if (len < 4) {
  828. rc = -EINVAL;
  829. kfree_skb(skb);
  830. goto out_node;
  831. }
  832. /* control messages already require the type as 'command' */
  833. skb_copy_bits(skb, 0, &qrtr_type, 4);
  834. }
  835. type = le32_to_cpu(qrtr_type);
  836. rc = enqueue_fn(node, skb, type, &ipc->us, addr);
  837. if (rc >= 0)
  838. rc = len;
  839. out_node:
  840. qrtr_node_release(node);
  841. release_sock(sk);
  842. return rc;
  843. }
  844. static int qrtr_send_resume_tx(struct qrtr_cb *cb)
  845. {
  846. struct sockaddr_qrtr remote = { AF_QIPCRTR, cb->src_node, cb->src_port };
  847. struct sockaddr_qrtr local = { AF_QIPCRTR, cb->dst_node, cb->dst_port };
  848. struct qrtr_ctrl_pkt *pkt;
  849. struct qrtr_node *node;
  850. struct sk_buff *skb;
  851. int ret;
  852. node = qrtr_node_lookup(remote.sq_node);
  853. if (!node)
  854. return -EINVAL;
  855. skb = qrtr_alloc_ctrl_packet(&pkt, GFP_KERNEL);
  856. if (!skb)
  857. return -ENOMEM;
  858. pkt->cmd = cpu_to_le32(QRTR_TYPE_RESUME_TX);
  859. pkt->client.node = cpu_to_le32(cb->dst_node);
  860. pkt->client.port = cpu_to_le32(cb->dst_port);
  861. ret = qrtr_node_enqueue(node, skb, QRTR_TYPE_RESUME_TX, &local, &remote);
  862. qrtr_node_release(node);
  863. return ret;
  864. }
  865. static int qrtr_recvmsg(struct socket *sock, struct msghdr *msg,
  866. size_t size, int flags)
  867. {
  868. DECLARE_SOCKADDR(struct sockaddr_qrtr *, addr, msg->msg_name);
  869. struct sock *sk = sock->sk;
  870. struct sk_buff *skb;
  871. struct qrtr_cb *cb;
  872. int copied, rc;
  873. lock_sock(sk);
  874. if (sock_flag(sk, SOCK_ZAPPED)) {
  875. release_sock(sk);
  876. return -EADDRNOTAVAIL;
  877. }
  878. skb = skb_recv_datagram(sk, flags, &rc);
  879. if (!skb) {
  880. release_sock(sk);
  881. return rc;
  882. }
  883. cb = (struct qrtr_cb *)skb->cb;
  884. copied = skb->len;
  885. if (copied > size) {
  886. copied = size;
  887. msg->msg_flags |= MSG_TRUNC;
  888. }
  889. rc = skb_copy_datagram_msg(skb, 0, msg, copied);
  890. if (rc < 0)
  891. goto out;
  892. rc = copied;
  893. if (addr) {
  894. /* There is an anonymous 2-byte hole after sq_family,
  895. * make sure to clear it.
  896. */
  897. memset(addr, 0, sizeof(*addr));
  898. addr->sq_family = AF_QIPCRTR;
  899. addr->sq_node = cb->src_node;
  900. addr->sq_port = cb->src_port;
  901. msg->msg_namelen = sizeof(*addr);
  902. }
  903. out:
  904. if (cb->confirm_rx)
  905. qrtr_send_resume_tx(cb);
  906. skb_free_datagram(sk, skb);
  907. release_sock(sk);
  908. return rc;
  909. }
  910. static int qrtr_connect(struct socket *sock, struct sockaddr *saddr,
  911. int len, int flags)
  912. {
  913. DECLARE_SOCKADDR(struct sockaddr_qrtr *, addr, saddr);
  914. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  915. struct sock *sk = sock->sk;
  916. int rc;
  917. if (len < sizeof(*addr) || addr->sq_family != AF_QIPCRTR)
  918. return -EINVAL;
  919. lock_sock(sk);
  920. sk->sk_state = TCP_CLOSE;
  921. sock->state = SS_UNCONNECTED;
  922. rc = qrtr_autobind(sock);
  923. if (rc) {
  924. release_sock(sk);
  925. return rc;
  926. }
  927. ipc->peer = *addr;
  928. sock->state = SS_CONNECTED;
  929. sk->sk_state = TCP_ESTABLISHED;
  930. release_sock(sk);
  931. return 0;
  932. }
  933. static int qrtr_getname(struct socket *sock, struct sockaddr *saddr,
  934. int peer)
  935. {
  936. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  937. struct sockaddr_qrtr qaddr;
  938. struct sock *sk = sock->sk;
  939. lock_sock(sk);
  940. if (peer) {
  941. if (sk->sk_state != TCP_ESTABLISHED) {
  942. release_sock(sk);
  943. return -ENOTCONN;
  944. }
  945. qaddr = ipc->peer;
  946. } else {
  947. qaddr = ipc->us;
  948. }
  949. release_sock(sk);
  950. qaddr.sq_family = AF_QIPCRTR;
  951. memcpy(saddr, &qaddr, sizeof(qaddr));
  952. return sizeof(qaddr);
  953. }
  954. static int qrtr_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
  955. {
  956. void __user *argp = (void __user *)arg;
  957. struct qrtr_sock *ipc = qrtr_sk(sock->sk);
  958. struct sock *sk = sock->sk;
  959. struct sockaddr_qrtr *sq;
  960. struct sk_buff *skb;
  961. struct ifreq ifr;
  962. long len = 0;
  963. int rc = 0;
  964. lock_sock(sk);
  965. switch (cmd) {
  966. case TIOCOUTQ:
  967. len = sk->sk_sndbuf - sk_wmem_alloc_get(sk);
  968. if (len < 0)
  969. len = 0;
  970. rc = put_user(len, (int __user *)argp);
  971. break;
  972. case TIOCINQ:
  973. skb = skb_peek(&sk->sk_receive_queue);
  974. if (skb)
  975. len = skb->len;
  976. rc = put_user(len, (int __user *)argp);
  977. break;
  978. case SIOCGIFADDR:
  979. if (get_user_ifreq(&ifr, NULL, argp)) {
  980. rc = -EFAULT;
  981. break;
  982. }
  983. sq = (struct sockaddr_qrtr *)&ifr.ifr_addr;
  984. *sq = ipc->us;
  985. if (put_user_ifreq(&ifr, argp)) {
  986. rc = -EFAULT;
  987. break;
  988. }
  989. break;
  990. case SIOCADDRT:
  991. case SIOCDELRT:
  992. case SIOCSIFADDR:
  993. case SIOCGIFDSTADDR:
  994. case SIOCSIFDSTADDR:
  995. case SIOCGIFBRDADDR:
  996. case SIOCSIFBRDADDR:
  997. case SIOCGIFNETMASK:
  998. case SIOCSIFNETMASK:
  999. rc = -EINVAL;
  1000. break;
  1001. default:
  1002. rc = -ENOIOCTLCMD;
  1003. break;
  1004. }
  1005. release_sock(sk);
  1006. return rc;
  1007. }
  1008. static int qrtr_release(struct socket *sock)
  1009. {
  1010. struct sock *sk = sock->sk;
  1011. struct qrtr_sock *ipc;
  1012. if (!sk)
  1013. return 0;
  1014. lock_sock(sk);
  1015. ipc = qrtr_sk(sk);
  1016. sk->sk_shutdown = SHUTDOWN_MASK;
  1017. if (!sock_flag(sk, SOCK_DEAD))
  1018. sk->sk_state_change(sk);
  1019. sock_set_flag(sk, SOCK_DEAD);
  1020. sock_orphan(sk);
  1021. sock->sk = NULL;
  1022. if (!sock_flag(sk, SOCK_ZAPPED))
  1023. qrtr_port_remove(ipc);
  1024. skb_queue_purge(&sk->sk_receive_queue);
  1025. release_sock(sk);
  1026. sock_put(sk);
  1027. return 0;
  1028. }
  1029. static const struct proto_ops qrtr_proto_ops = {
  1030. .owner = THIS_MODULE,
  1031. .family = AF_QIPCRTR,
  1032. .bind = qrtr_bind,
  1033. .connect = qrtr_connect,
  1034. .socketpair = sock_no_socketpair,
  1035. .accept = sock_no_accept,
  1036. .listen = sock_no_listen,
  1037. .sendmsg = qrtr_sendmsg,
  1038. .recvmsg = qrtr_recvmsg,
  1039. .getname = qrtr_getname,
  1040. .ioctl = qrtr_ioctl,
  1041. .gettstamp = sock_gettstamp,
  1042. .poll = datagram_poll,
  1043. .shutdown = sock_no_shutdown,
  1044. .release = qrtr_release,
  1045. .mmap = sock_no_mmap,
  1046. };
  1047. static struct proto qrtr_proto = {
  1048. .name = "QIPCRTR",
  1049. .owner = THIS_MODULE,
  1050. .obj_size = sizeof(struct qrtr_sock),
  1051. };
  1052. static int qrtr_create(struct net *net, struct socket *sock,
  1053. int protocol, int kern)
  1054. {
  1055. struct qrtr_sock *ipc;
  1056. struct sock *sk;
  1057. if (sock->type != SOCK_DGRAM)
  1058. return -EPROTOTYPE;
  1059. sk = sk_alloc(net, AF_QIPCRTR, GFP_KERNEL, &qrtr_proto, kern);
  1060. if (!sk)
  1061. return -ENOMEM;
  1062. sock_set_flag(sk, SOCK_ZAPPED);
  1063. sock_init_data(sock, sk);
  1064. sock->ops = &qrtr_proto_ops;
  1065. ipc = qrtr_sk(sk);
  1066. ipc->us.sq_family = AF_QIPCRTR;
  1067. ipc->us.sq_node = qrtr_local_nid;
  1068. ipc->us.sq_port = 0;
  1069. return 0;
  1070. }
  1071. static const struct net_proto_family qrtr_family = {
  1072. .owner = THIS_MODULE,
  1073. .family = AF_QIPCRTR,
  1074. .create = qrtr_create,
  1075. };
  1076. static int __init qrtr_proto_init(void)
  1077. {
  1078. int rc;
  1079. rc = proto_register(&qrtr_proto, 1);
  1080. if (rc)
  1081. return rc;
  1082. rc = sock_register(&qrtr_family);
  1083. if (rc)
  1084. goto err_proto;
  1085. rc = qrtr_ns_init();
  1086. if (rc)
  1087. goto err_sock;
  1088. return 0;
  1089. err_sock:
  1090. sock_unregister(qrtr_family.family);
  1091. err_proto:
  1092. proto_unregister(&qrtr_proto);
  1093. return rc;
  1094. }
  1095. postcore_initcall(qrtr_proto_init);
  1096. static void __exit qrtr_proto_fini(void)
  1097. {
  1098. qrtr_ns_remove();
  1099. sock_unregister(qrtr_family.family);
  1100. proto_unregister(&qrtr_proto);
  1101. }
  1102. module_exit(qrtr_proto_fini);
  1103. MODULE_DESCRIPTION("Qualcomm IPC-router driver");
  1104. MODULE_LICENSE("GPL v2");
  1105. MODULE_ALIAS_NETPROTO(PF_QIPCRTR);