• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Copyright (C) 2011 Instituto Nokia de Tecnologia
4  *
5  * Authors:
6  *    Lauro Ramos Venancio <lauro.venancio@openbossa.org>
7  *    Aloisio Almeida Jr <aloisio.almeida@openbossa.org>
8  */
9 
10 #define pr_fmt(fmt) KBUILD_MODNAME ": %s: " fmt, __func__
11 
12 #include <linux/init.h>
13 #include <linux/kernel.h>
14 #include <linux/module.h>
15 #include <linux/slab.h>
16 #include <linux/rfkill.h>
17 #include <linux/nfc.h>
18 
19 #include <net/genetlink.h>
20 
21 #include "nfc.h"
22 
23 #define VERSION "0.1"
24 
25 #define NFC_CHECK_PRES_FREQ_MS	2000
26 
27 int nfc_devlist_generation;
28 DEFINE_MUTEX(nfc_devlist_mutex);
29 
30 /* NFC device ID bitmap */
31 static DEFINE_IDA(nfc_index_ida);
32 
nfc_fw_download(struct nfc_dev * dev,const char * firmware_name)33 int nfc_fw_download(struct nfc_dev *dev, const char *firmware_name)
34 {
35 	int rc = 0;
36 
37 	pr_debug("%s do firmware %s\n", dev_name(&dev->dev), firmware_name);
38 
39 	device_lock(&dev->dev);
40 
41 	if (!device_is_registered(&dev->dev)) {
42 		rc = -ENODEV;
43 		goto error;
44 	}
45 
46 	if (dev->dev_up) {
47 		rc = -EBUSY;
48 		goto error;
49 	}
50 
51 	if (!dev->ops->fw_download) {
52 		rc = -EOPNOTSUPP;
53 		goto error;
54 	}
55 
56 	dev->fw_download_in_progress = true;
57 	rc = dev->ops->fw_download(dev, firmware_name);
58 	if (rc)
59 		dev->fw_download_in_progress = false;
60 
61 error:
62 	device_unlock(&dev->dev);
63 	return rc;
64 }
65 
66 /**
67  * nfc_fw_download_done - inform that a firmware download was completed
68  *
69  * @dev: The nfc device to which firmware was downloaded
70  * @firmware_name: The firmware filename
71  * @result: The positive value of a standard errno value
72  */
nfc_fw_download_done(struct nfc_dev * dev,const char * firmware_name,u32 result)73 int nfc_fw_download_done(struct nfc_dev *dev, const char *firmware_name,
74 			 u32 result)
75 {
76 	dev->fw_download_in_progress = false;
77 
78 	return nfc_genl_fw_download_done(dev, firmware_name, result);
79 }
80 EXPORT_SYMBOL(nfc_fw_download_done);
81 
82 /**
83  * nfc_dev_up - turn on the NFC device
84  *
85  * @dev: The nfc device to be turned on
86  *
87  * The device remains up until the nfc_dev_down function is called.
88  */
nfc_dev_up(struct nfc_dev * dev)89 int nfc_dev_up(struct nfc_dev *dev)
90 {
91 	int rc = 0;
92 
93 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
94 
95 	device_lock(&dev->dev);
96 
97 	if (dev->rfkill && rfkill_blocked(dev->rfkill)) {
98 		rc = -ERFKILL;
99 		goto error;
100 	}
101 
102 	if (!device_is_registered(&dev->dev)) {
103 		rc = -ENODEV;
104 		goto error;
105 	}
106 
107 	if (dev->fw_download_in_progress) {
108 		rc = -EBUSY;
109 		goto error;
110 	}
111 
112 	if (dev->dev_up) {
113 		rc = -EALREADY;
114 		goto error;
115 	}
116 
117 	if (dev->ops->dev_up)
118 		rc = dev->ops->dev_up(dev);
119 
120 	if (!rc)
121 		dev->dev_up = true;
122 
123 	/* We have to enable the device before discovering SEs */
124 	if (dev->ops->discover_se && dev->ops->discover_se(dev))
125 		pr_err("SE discovery failed\n");
126 
127 error:
128 	device_unlock(&dev->dev);
129 	return rc;
130 }
131 
132 /**
133  * nfc_dev_down - turn off the NFC device
134  *
135  * @dev: The nfc device to be turned off
136  */
nfc_dev_down(struct nfc_dev * dev)137 int nfc_dev_down(struct nfc_dev *dev)
138 {
139 	int rc = 0;
140 
141 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
142 
143 	device_lock(&dev->dev);
144 
145 	if (!device_is_registered(&dev->dev)) {
146 		rc = -ENODEV;
147 		goto error;
148 	}
149 
150 	if (!dev->dev_up) {
151 		rc = -EALREADY;
152 		goto error;
153 	}
154 
155 	if (dev->polling || dev->active_target) {
156 		rc = -EBUSY;
157 		goto error;
158 	}
159 
160 	if (dev->ops->dev_down)
161 		dev->ops->dev_down(dev);
162 
163 	dev->dev_up = false;
164 
165 error:
166 	device_unlock(&dev->dev);
167 	return rc;
168 }
169 
nfc_rfkill_set_block(void * data,bool blocked)170 static int nfc_rfkill_set_block(void *data, bool blocked)
171 {
172 	struct nfc_dev *dev = data;
173 
174 	pr_debug("%s blocked %d", dev_name(&dev->dev), blocked);
175 
176 	if (!blocked)
177 		return 0;
178 
179 	nfc_dev_down(dev);
180 
181 	return 0;
182 }
183 
184 static const struct rfkill_ops nfc_rfkill_ops = {
185 	.set_block = nfc_rfkill_set_block,
186 };
187 
188 /**
189  * nfc_start_poll - start polling for nfc targets
190  *
191  * @dev: The nfc device that must start polling
192  * @protocols: bitset of nfc protocols that must be used for polling
193  *
194  * The device remains polling for targets until a target is found or
195  * the nfc_stop_poll function is called.
196  */
nfc_start_poll(struct nfc_dev * dev,u32 im_protocols,u32 tm_protocols)197 int nfc_start_poll(struct nfc_dev *dev, u32 im_protocols, u32 tm_protocols)
198 {
199 	int rc;
200 
201 	pr_debug("dev_name %s initiator protocols 0x%x target protocols 0x%x\n",
202 		 dev_name(&dev->dev), im_protocols, tm_protocols);
203 
204 	if (!im_protocols && !tm_protocols)
205 		return -EINVAL;
206 
207 	device_lock(&dev->dev);
208 
209 	if (!device_is_registered(&dev->dev)) {
210 		rc = -ENODEV;
211 		goto error;
212 	}
213 
214 	if (!dev->dev_up) {
215 		rc = -ENODEV;
216 		goto error;
217 	}
218 
219 	if (dev->polling) {
220 		rc = -EBUSY;
221 		goto error;
222 	}
223 
224 	rc = dev->ops->start_poll(dev, im_protocols, tm_protocols);
225 	if (!rc) {
226 		dev->polling = true;
227 		dev->rf_mode = NFC_RF_NONE;
228 	}
229 
230 error:
231 	device_unlock(&dev->dev);
232 	return rc;
233 }
234 
235 /**
236  * nfc_stop_poll - stop polling for nfc targets
237  *
238  * @dev: The nfc device that must stop polling
239  */
nfc_stop_poll(struct nfc_dev * dev)240 int nfc_stop_poll(struct nfc_dev *dev)
241 {
242 	int rc = 0;
243 
244 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
245 
246 	device_lock(&dev->dev);
247 
248 	if (!device_is_registered(&dev->dev)) {
249 		rc = -ENODEV;
250 		goto error;
251 	}
252 
253 	if (!dev->polling) {
254 		rc = -EINVAL;
255 		goto error;
256 	}
257 
258 	dev->ops->stop_poll(dev);
259 	dev->polling = false;
260 	dev->rf_mode = NFC_RF_NONE;
261 
262 error:
263 	device_unlock(&dev->dev);
264 	return rc;
265 }
266 
nfc_find_target(struct nfc_dev * dev,u32 target_idx)267 static struct nfc_target *nfc_find_target(struct nfc_dev *dev, u32 target_idx)
268 {
269 	int i;
270 
271 	for (i = 0; i < dev->n_targets; i++) {
272 		if (dev->targets[i].idx == target_idx)
273 			return &dev->targets[i];
274 	}
275 
276 	return NULL;
277 }
278 
nfc_dep_link_up(struct nfc_dev * dev,int target_index,u8 comm_mode)279 int nfc_dep_link_up(struct nfc_dev *dev, int target_index, u8 comm_mode)
280 {
281 	int rc = 0;
282 	u8 *gb;
283 	size_t gb_len;
284 	struct nfc_target *target;
285 
286 	pr_debug("dev_name=%s comm %d\n", dev_name(&dev->dev), comm_mode);
287 
288 	if (!dev->ops->dep_link_up)
289 		return -EOPNOTSUPP;
290 
291 	device_lock(&dev->dev);
292 
293 	if (!device_is_registered(&dev->dev)) {
294 		rc = -ENODEV;
295 		goto error;
296 	}
297 
298 	if (dev->dep_link_up == true) {
299 		rc = -EALREADY;
300 		goto error;
301 	}
302 
303 	gb = nfc_llcp_general_bytes(dev, &gb_len);
304 	if (gb_len > NFC_MAX_GT_LEN) {
305 		rc = -EINVAL;
306 		goto error;
307 	}
308 
309 	target = nfc_find_target(dev, target_index);
310 	if (target == NULL) {
311 		rc = -ENOTCONN;
312 		goto error;
313 	}
314 
315 	rc = dev->ops->dep_link_up(dev, target, comm_mode, gb, gb_len);
316 	if (!rc) {
317 		dev->active_target = target;
318 		dev->rf_mode = NFC_RF_INITIATOR;
319 	}
320 
321 error:
322 	device_unlock(&dev->dev);
323 	return rc;
324 }
325 
nfc_dep_link_down(struct nfc_dev * dev)326 int nfc_dep_link_down(struct nfc_dev *dev)
327 {
328 	int rc = 0;
329 
330 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
331 
332 	if (!dev->ops->dep_link_down)
333 		return -EOPNOTSUPP;
334 
335 	device_lock(&dev->dev);
336 
337 	if (!device_is_registered(&dev->dev)) {
338 		rc = -ENODEV;
339 		goto error;
340 	}
341 
342 	if (dev->dep_link_up == false) {
343 		rc = -EALREADY;
344 		goto error;
345 	}
346 
347 	rc = dev->ops->dep_link_down(dev);
348 	if (!rc) {
349 		dev->dep_link_up = false;
350 		dev->active_target = NULL;
351 		dev->rf_mode = NFC_RF_NONE;
352 		nfc_llcp_mac_is_down(dev);
353 		nfc_genl_dep_link_down_event(dev);
354 	}
355 
356 error:
357 	device_unlock(&dev->dev);
358 
359 	return rc;
360 }
361 
nfc_dep_link_is_up(struct nfc_dev * dev,u32 target_idx,u8 comm_mode,u8 rf_mode)362 int nfc_dep_link_is_up(struct nfc_dev *dev, u32 target_idx,
363 		       u8 comm_mode, u8 rf_mode)
364 {
365 	dev->dep_link_up = true;
366 
367 	if (!dev->active_target && rf_mode == NFC_RF_INITIATOR) {
368 		struct nfc_target *target;
369 
370 		target = nfc_find_target(dev, target_idx);
371 		if (target == NULL)
372 			return -ENOTCONN;
373 
374 		dev->active_target = target;
375 	}
376 
377 	dev->polling = false;
378 	dev->rf_mode = rf_mode;
379 
380 	nfc_llcp_mac_is_up(dev, target_idx, comm_mode, rf_mode);
381 
382 	return nfc_genl_dep_link_up_event(dev, target_idx, comm_mode, rf_mode);
383 }
384 EXPORT_SYMBOL(nfc_dep_link_is_up);
385 
386 /**
387  * nfc_activate_target - prepare the target for data exchange
388  *
389  * @dev: The nfc device that found the target
390  * @target_idx: index of the target that must be activated
391  * @protocol: nfc protocol that will be used for data exchange
392  */
nfc_activate_target(struct nfc_dev * dev,u32 target_idx,u32 protocol)393 int nfc_activate_target(struct nfc_dev *dev, u32 target_idx, u32 protocol)
394 {
395 	int rc;
396 	struct nfc_target *target;
397 
398 	pr_debug("dev_name=%s target_idx=%u protocol=%u\n",
399 		 dev_name(&dev->dev), target_idx, protocol);
400 
401 	device_lock(&dev->dev);
402 
403 	if (!device_is_registered(&dev->dev)) {
404 		rc = -ENODEV;
405 		goto error;
406 	}
407 
408 	if (dev->active_target) {
409 		rc = -EBUSY;
410 		goto error;
411 	}
412 
413 	target = nfc_find_target(dev, target_idx);
414 	if (target == NULL) {
415 		rc = -ENOTCONN;
416 		goto error;
417 	}
418 
419 	rc = dev->ops->activate_target(dev, target, protocol);
420 	if (!rc) {
421 		dev->active_target = target;
422 		dev->rf_mode = NFC_RF_INITIATOR;
423 
424 		if (dev->ops->check_presence && !dev->shutting_down)
425 			mod_timer(&dev->check_pres_timer, jiffies +
426 				  msecs_to_jiffies(NFC_CHECK_PRES_FREQ_MS));
427 	}
428 
429 error:
430 	device_unlock(&dev->dev);
431 	return rc;
432 }
433 
434 /**
435  * nfc_deactivate_target - deactivate a nfc target
436  *
437  * @dev: The nfc device that found the target
438  * @target_idx: index of the target that must be deactivated
439  */
nfc_deactivate_target(struct nfc_dev * dev,u32 target_idx,u8 mode)440 int nfc_deactivate_target(struct nfc_dev *dev, u32 target_idx, u8 mode)
441 {
442 	int rc = 0;
443 
444 	pr_debug("dev_name=%s target_idx=%u\n",
445 		 dev_name(&dev->dev), target_idx);
446 
447 	device_lock(&dev->dev);
448 
449 	if (!device_is_registered(&dev->dev)) {
450 		rc = -ENODEV;
451 		goto error;
452 	}
453 
454 	if (dev->active_target == NULL) {
455 		rc = -ENOTCONN;
456 		goto error;
457 	}
458 
459 	if (dev->active_target->idx != target_idx) {
460 		rc = -ENOTCONN;
461 		goto error;
462 	}
463 
464 	if (dev->ops->check_presence)
465 		del_timer_sync(&dev->check_pres_timer);
466 
467 	dev->ops->deactivate_target(dev, dev->active_target, mode);
468 	dev->active_target = NULL;
469 
470 error:
471 	device_unlock(&dev->dev);
472 	return rc;
473 }
474 
475 /**
476  * nfc_data_exchange - transceive data
477  *
478  * @dev: The nfc device that found the target
479  * @target_idx: index of the target
480  * @skb: data to be sent
481  * @cb: callback called when the response is received
482  * @cb_context: parameter for the callback function
483  *
484  * The user must wait for the callback before calling this function again.
485  */
nfc_data_exchange(struct nfc_dev * dev,u32 target_idx,struct sk_buff * skb,data_exchange_cb_t cb,void * cb_context)486 int nfc_data_exchange(struct nfc_dev *dev, u32 target_idx, struct sk_buff *skb,
487 		      data_exchange_cb_t cb, void *cb_context)
488 {
489 	int rc;
490 
491 	pr_debug("dev_name=%s target_idx=%u skb->len=%u\n",
492 		 dev_name(&dev->dev), target_idx, skb->len);
493 
494 	device_lock(&dev->dev);
495 
496 	if (!device_is_registered(&dev->dev)) {
497 		rc = -ENODEV;
498 		kfree_skb(skb);
499 		goto error;
500 	}
501 
502 	if (dev->rf_mode == NFC_RF_INITIATOR && dev->active_target != NULL) {
503 		if (dev->active_target->idx != target_idx) {
504 			rc = -EADDRNOTAVAIL;
505 			kfree_skb(skb);
506 			goto error;
507 		}
508 
509 		if (dev->ops->check_presence)
510 			del_timer_sync(&dev->check_pres_timer);
511 
512 		rc = dev->ops->im_transceive(dev, dev->active_target, skb, cb,
513 					     cb_context);
514 
515 		if (!rc && dev->ops->check_presence && !dev->shutting_down)
516 			mod_timer(&dev->check_pres_timer, jiffies +
517 				  msecs_to_jiffies(NFC_CHECK_PRES_FREQ_MS));
518 	} else if (dev->rf_mode == NFC_RF_TARGET && dev->ops->tm_send != NULL) {
519 		rc = dev->ops->tm_send(dev, skb);
520 	} else {
521 		rc = -ENOTCONN;
522 		kfree_skb(skb);
523 		goto error;
524 	}
525 
526 
527 error:
528 	device_unlock(&dev->dev);
529 	return rc;
530 }
531 
nfc_find_se(struct nfc_dev * dev,u32 se_idx)532 struct nfc_se *nfc_find_se(struct nfc_dev *dev, u32 se_idx)
533 {
534 	struct nfc_se *se;
535 
536 	list_for_each_entry(se, &dev->secure_elements, list)
537 		if (se->idx == se_idx)
538 			return se;
539 
540 	return NULL;
541 }
542 EXPORT_SYMBOL(nfc_find_se);
543 
nfc_enable_se(struct nfc_dev * dev,u32 se_idx)544 int nfc_enable_se(struct nfc_dev *dev, u32 se_idx)
545 {
546 	struct nfc_se *se;
547 	int rc;
548 
549 	pr_debug("%s se index %d\n", dev_name(&dev->dev), se_idx);
550 
551 	device_lock(&dev->dev);
552 
553 	if (!device_is_registered(&dev->dev)) {
554 		rc = -ENODEV;
555 		goto error;
556 	}
557 
558 	if (!dev->dev_up) {
559 		rc = -ENODEV;
560 		goto error;
561 	}
562 
563 	if (dev->polling) {
564 		rc = -EBUSY;
565 		goto error;
566 	}
567 
568 	if (!dev->ops->enable_se || !dev->ops->disable_se) {
569 		rc = -EOPNOTSUPP;
570 		goto error;
571 	}
572 
573 	se = nfc_find_se(dev, se_idx);
574 	if (!se) {
575 		rc = -EINVAL;
576 		goto error;
577 	}
578 
579 	if (se->state == NFC_SE_ENABLED) {
580 		rc = -EALREADY;
581 		goto error;
582 	}
583 
584 	rc = dev->ops->enable_se(dev, se_idx);
585 	if (rc >= 0)
586 		se->state = NFC_SE_ENABLED;
587 
588 error:
589 	device_unlock(&dev->dev);
590 	return rc;
591 }
592 
nfc_disable_se(struct nfc_dev * dev,u32 se_idx)593 int nfc_disable_se(struct nfc_dev *dev, u32 se_idx)
594 {
595 	struct nfc_se *se;
596 	int rc;
597 
598 	pr_debug("%s se index %d\n", dev_name(&dev->dev), se_idx);
599 
600 	device_lock(&dev->dev);
601 
602 	if (!device_is_registered(&dev->dev)) {
603 		rc = -ENODEV;
604 		goto error;
605 	}
606 
607 	if (!dev->dev_up) {
608 		rc = -ENODEV;
609 		goto error;
610 	}
611 
612 	if (!dev->ops->enable_se || !dev->ops->disable_se) {
613 		rc = -EOPNOTSUPP;
614 		goto error;
615 	}
616 
617 	se = nfc_find_se(dev, se_idx);
618 	if (!se) {
619 		rc = -EINVAL;
620 		goto error;
621 	}
622 
623 	if (se->state == NFC_SE_DISABLED) {
624 		rc = -EALREADY;
625 		goto error;
626 	}
627 
628 	rc = dev->ops->disable_se(dev, se_idx);
629 	if (rc >= 0)
630 		se->state = NFC_SE_DISABLED;
631 
632 error:
633 	device_unlock(&dev->dev);
634 	return rc;
635 }
636 
nfc_set_remote_general_bytes(struct nfc_dev * dev,u8 * gb,u8 gb_len)637 int nfc_set_remote_general_bytes(struct nfc_dev *dev, u8 *gb, u8 gb_len)
638 {
639 	pr_debug("dev_name=%s gb_len=%d\n", dev_name(&dev->dev), gb_len);
640 
641 	return nfc_llcp_set_remote_gb(dev, gb, gb_len);
642 }
643 EXPORT_SYMBOL(nfc_set_remote_general_bytes);
644 
nfc_get_local_general_bytes(struct nfc_dev * dev,size_t * gb_len)645 u8 *nfc_get_local_general_bytes(struct nfc_dev *dev, size_t *gb_len)
646 {
647 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
648 
649 	return nfc_llcp_general_bytes(dev, gb_len);
650 }
651 EXPORT_SYMBOL(nfc_get_local_general_bytes);
652 
nfc_tm_data_received(struct nfc_dev * dev,struct sk_buff * skb)653 int nfc_tm_data_received(struct nfc_dev *dev, struct sk_buff *skb)
654 {
655 	/* Only LLCP target mode for now */
656 	if (dev->dep_link_up == false) {
657 		kfree_skb(skb);
658 		return -ENOLINK;
659 	}
660 
661 	return nfc_llcp_data_received(dev, skb);
662 }
663 EXPORT_SYMBOL(nfc_tm_data_received);
664 
nfc_tm_activated(struct nfc_dev * dev,u32 protocol,u8 comm_mode,u8 * gb,size_t gb_len)665 int nfc_tm_activated(struct nfc_dev *dev, u32 protocol, u8 comm_mode,
666 		     u8 *gb, size_t gb_len)
667 {
668 	int rc;
669 
670 	device_lock(&dev->dev);
671 
672 	dev->polling = false;
673 
674 	if (gb != NULL) {
675 		rc = nfc_set_remote_general_bytes(dev, gb, gb_len);
676 		if (rc < 0)
677 			goto out;
678 	}
679 
680 	dev->rf_mode = NFC_RF_TARGET;
681 
682 	if (protocol == NFC_PROTO_NFC_DEP_MASK)
683 		nfc_dep_link_is_up(dev, 0, comm_mode, NFC_RF_TARGET);
684 
685 	rc = nfc_genl_tm_activated(dev, protocol);
686 
687 out:
688 	device_unlock(&dev->dev);
689 
690 	return rc;
691 }
692 EXPORT_SYMBOL(nfc_tm_activated);
693 
nfc_tm_deactivated(struct nfc_dev * dev)694 int nfc_tm_deactivated(struct nfc_dev *dev)
695 {
696 	dev->dep_link_up = false;
697 	dev->rf_mode = NFC_RF_NONE;
698 
699 	return nfc_genl_tm_deactivated(dev);
700 }
701 EXPORT_SYMBOL(nfc_tm_deactivated);
702 
703 /**
704  * nfc_alloc_send_skb - allocate a skb for data exchange responses
705  *
706  * @size: size to allocate
707  * @gfp: gfp flags
708  */
nfc_alloc_send_skb(struct nfc_dev * dev,struct sock * sk,unsigned int flags,unsigned int size,unsigned int * err)709 struct sk_buff *nfc_alloc_send_skb(struct nfc_dev *dev, struct sock *sk,
710 				   unsigned int flags, unsigned int size,
711 				   unsigned int *err)
712 {
713 	struct sk_buff *skb;
714 	unsigned int total_size;
715 
716 	total_size = size +
717 		dev->tx_headroom + dev->tx_tailroom + NFC_HEADER_SIZE;
718 
719 	skb = sock_alloc_send_skb(sk, total_size, flags & MSG_DONTWAIT, err);
720 	if (skb)
721 		skb_reserve(skb, dev->tx_headroom + NFC_HEADER_SIZE);
722 
723 	return skb;
724 }
725 
726 /**
727  * nfc_alloc_recv_skb - allocate a skb for data exchange responses
728  *
729  * @size: size to allocate
730  * @gfp: gfp flags
731  */
nfc_alloc_recv_skb(unsigned int size,gfp_t gfp)732 struct sk_buff *nfc_alloc_recv_skb(unsigned int size, gfp_t gfp)
733 {
734 	struct sk_buff *skb;
735 	unsigned int total_size;
736 
737 	total_size = size + 1;
738 	skb = alloc_skb(total_size, gfp);
739 
740 	if (skb)
741 		skb_reserve(skb, 1);
742 
743 	return skb;
744 }
745 EXPORT_SYMBOL(nfc_alloc_recv_skb);
746 
747 /**
748  * nfc_targets_found - inform that targets were found
749  *
750  * @dev: The nfc device that found the targets
751  * @targets: array of nfc targets found
752  * @ntargets: targets array size
753  *
754  * The device driver must call this function when one or many nfc targets
755  * are found. After calling this function, the device driver must stop
756  * polling for targets.
757  * NOTE: This function can be called with targets=NULL and n_targets=0 to
758  * notify a driver error, meaning that the polling operation cannot complete.
759  * IMPORTANT: this function must not be called from an atomic context.
760  * In addition, it must also not be called from a context that would prevent
761  * the NFC Core to call other nfc ops entry point concurrently.
762  */
nfc_targets_found(struct nfc_dev * dev,struct nfc_target * targets,int n_targets)763 int nfc_targets_found(struct nfc_dev *dev,
764 		      struct nfc_target *targets, int n_targets)
765 {
766 	int i;
767 
768 	pr_debug("dev_name=%s n_targets=%d\n", dev_name(&dev->dev), n_targets);
769 
770 	for (i = 0; i < n_targets; i++)
771 		targets[i].idx = dev->target_next_idx++;
772 
773 	device_lock(&dev->dev);
774 
775 	if (dev->polling == false) {
776 		device_unlock(&dev->dev);
777 		return 0;
778 	}
779 
780 	dev->polling = false;
781 
782 	dev->targets_generation++;
783 
784 	kfree(dev->targets);
785 	dev->targets = NULL;
786 
787 	if (targets) {
788 		dev->targets = kmemdup(targets,
789 				       n_targets * sizeof(struct nfc_target),
790 				       GFP_ATOMIC);
791 
792 		if (!dev->targets) {
793 			dev->n_targets = 0;
794 			device_unlock(&dev->dev);
795 			return -ENOMEM;
796 		}
797 	}
798 
799 	dev->n_targets = n_targets;
800 	device_unlock(&dev->dev);
801 
802 	nfc_genl_targets_found(dev);
803 
804 	return 0;
805 }
806 EXPORT_SYMBOL(nfc_targets_found);
807 
808 /**
809  * nfc_target_lost - inform that an activated target went out of field
810  *
811  * @dev: The nfc device that had the activated target in field
812  * @target_idx: the nfc index of the target
813  *
814  * The device driver must call this function when the activated target
815  * goes out of the field.
816  * IMPORTANT: this function must not be called from an atomic context.
817  * In addition, it must also not be called from a context that would prevent
818  * the NFC Core to call other nfc ops entry point concurrently.
819  */
nfc_target_lost(struct nfc_dev * dev,u32 target_idx)820 int nfc_target_lost(struct nfc_dev *dev, u32 target_idx)
821 {
822 	struct nfc_target *tg;
823 	int i;
824 
825 	pr_debug("dev_name %s n_target %d\n", dev_name(&dev->dev), target_idx);
826 
827 	device_lock(&dev->dev);
828 
829 	for (i = 0; i < dev->n_targets; i++) {
830 		tg = &dev->targets[i];
831 		if (tg->idx == target_idx)
832 			break;
833 	}
834 
835 	if (i == dev->n_targets) {
836 		device_unlock(&dev->dev);
837 		return -EINVAL;
838 	}
839 
840 	dev->targets_generation++;
841 	dev->n_targets--;
842 	dev->active_target = NULL;
843 
844 	if (dev->n_targets) {
845 		memcpy(&dev->targets[i], &dev->targets[i + 1],
846 		       (dev->n_targets - i) * sizeof(struct nfc_target));
847 	} else {
848 		kfree(dev->targets);
849 		dev->targets = NULL;
850 	}
851 
852 	device_unlock(&dev->dev);
853 
854 	nfc_genl_target_lost(dev, target_idx);
855 
856 	return 0;
857 }
858 EXPORT_SYMBOL(nfc_target_lost);
859 
nfc_driver_failure(struct nfc_dev * dev,int err)860 inline void nfc_driver_failure(struct nfc_dev *dev, int err)
861 {
862 	nfc_targets_found(dev, NULL, 0);
863 }
864 EXPORT_SYMBOL(nfc_driver_failure);
865 
nfc_add_se(struct nfc_dev * dev,u32 se_idx,u16 type)866 int nfc_add_se(struct nfc_dev *dev, u32 se_idx, u16 type)
867 {
868 	struct nfc_se *se;
869 	int rc;
870 
871 	pr_debug("%s se index %d\n", dev_name(&dev->dev), se_idx);
872 
873 	se = nfc_find_se(dev, se_idx);
874 	if (se)
875 		return -EALREADY;
876 
877 	se = kzalloc(sizeof(struct nfc_se), GFP_KERNEL);
878 	if (!se)
879 		return -ENOMEM;
880 
881 	se->idx = se_idx;
882 	se->type = type;
883 	se->state = NFC_SE_DISABLED;
884 	INIT_LIST_HEAD(&se->list);
885 
886 	list_add(&se->list, &dev->secure_elements);
887 
888 	rc = nfc_genl_se_added(dev, se_idx, type);
889 	if (rc < 0) {
890 		list_del(&se->list);
891 		kfree(se);
892 
893 		return rc;
894 	}
895 
896 	return 0;
897 }
898 EXPORT_SYMBOL(nfc_add_se);
899 
nfc_remove_se(struct nfc_dev * dev,u32 se_idx)900 int nfc_remove_se(struct nfc_dev *dev, u32 se_idx)
901 {
902 	struct nfc_se *se, *n;
903 	int rc;
904 
905 	pr_debug("%s se index %d\n", dev_name(&dev->dev), se_idx);
906 
907 	list_for_each_entry_safe(se, n, &dev->secure_elements, list)
908 		if (se->idx == se_idx) {
909 			rc = nfc_genl_se_removed(dev, se_idx);
910 			if (rc < 0)
911 				return rc;
912 
913 			list_del(&se->list);
914 			kfree(se);
915 
916 			return 0;
917 		}
918 
919 	return -EINVAL;
920 }
921 EXPORT_SYMBOL(nfc_remove_se);
922 
nfc_se_transaction(struct nfc_dev * dev,u8 se_idx,struct nfc_evt_transaction * evt_transaction)923 int nfc_se_transaction(struct nfc_dev *dev, u8 se_idx,
924 		       struct nfc_evt_transaction *evt_transaction)
925 {
926 	int rc;
927 
928 	pr_debug("transaction: %x\n", se_idx);
929 
930 	device_lock(&dev->dev);
931 
932 	if (!evt_transaction) {
933 		rc = -EPROTO;
934 		goto out;
935 	}
936 
937 	rc = nfc_genl_se_transaction(dev, se_idx, evt_transaction);
938 out:
939 	device_unlock(&dev->dev);
940 	return rc;
941 }
942 EXPORT_SYMBOL(nfc_se_transaction);
943 
nfc_se_connectivity(struct nfc_dev * dev,u8 se_idx)944 int nfc_se_connectivity(struct nfc_dev *dev, u8 se_idx)
945 {
946 	int rc;
947 
948 	pr_debug("connectivity: %x\n", se_idx);
949 
950 	device_lock(&dev->dev);
951 	rc = nfc_genl_se_connectivity(dev, se_idx);
952 	device_unlock(&dev->dev);
953 	return rc;
954 }
955 EXPORT_SYMBOL(nfc_se_connectivity);
956 
nfc_release(struct device * d)957 static void nfc_release(struct device *d)
958 {
959 	struct nfc_dev *dev = to_nfc_dev(d);
960 	struct nfc_se *se, *n;
961 
962 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
963 
964 	nfc_genl_data_exit(&dev->genl_data);
965 	kfree(dev->targets);
966 
967 	list_for_each_entry_safe(se, n, &dev->secure_elements, list) {
968 			nfc_genl_se_removed(dev, se->idx);
969 			list_del(&se->list);
970 			kfree(se);
971 	}
972 
973 	ida_simple_remove(&nfc_index_ida, dev->idx);
974 
975 	kfree(dev);
976 }
977 
nfc_check_pres_work(struct work_struct * work)978 static void nfc_check_pres_work(struct work_struct *work)
979 {
980 	struct nfc_dev *dev = container_of(work, struct nfc_dev,
981 					   check_pres_work);
982 	int rc;
983 
984 	device_lock(&dev->dev);
985 
986 	if (dev->active_target && timer_pending(&dev->check_pres_timer) == 0) {
987 		rc = dev->ops->check_presence(dev, dev->active_target);
988 		if (rc == -EOPNOTSUPP)
989 			goto exit;
990 		if (rc) {
991 			u32 active_target_idx = dev->active_target->idx;
992 			device_unlock(&dev->dev);
993 			nfc_target_lost(dev, active_target_idx);
994 			return;
995 		}
996 
997 		if (!dev->shutting_down)
998 			mod_timer(&dev->check_pres_timer, jiffies +
999 				  msecs_to_jiffies(NFC_CHECK_PRES_FREQ_MS));
1000 	}
1001 
1002 exit:
1003 	device_unlock(&dev->dev);
1004 }
1005 
nfc_check_pres_timeout(struct timer_list * t)1006 static void nfc_check_pres_timeout(struct timer_list *t)
1007 {
1008 	struct nfc_dev *dev = from_timer(dev, t, check_pres_timer);
1009 
1010 	schedule_work(&dev->check_pres_work);
1011 }
1012 
1013 struct class nfc_class = {
1014 	.name = "nfc",
1015 	.dev_release = nfc_release,
1016 };
1017 EXPORT_SYMBOL(nfc_class);
1018 
match_idx(struct device * d,const void * data)1019 static int match_idx(struct device *d, const void *data)
1020 {
1021 	struct nfc_dev *dev = to_nfc_dev(d);
1022 	const unsigned int *idx = data;
1023 
1024 	return dev->idx == *idx;
1025 }
1026 
nfc_get_device(unsigned int idx)1027 struct nfc_dev *nfc_get_device(unsigned int idx)
1028 {
1029 	struct device *d;
1030 
1031 	d = class_find_device(&nfc_class, NULL, &idx, match_idx);
1032 	if (!d)
1033 		return NULL;
1034 
1035 	return to_nfc_dev(d);
1036 }
1037 
1038 /**
1039  * nfc_allocate_device - allocate a new nfc device
1040  *
1041  * @ops: device operations
1042  * @supported_protocols: NFC protocols supported by the device
1043  */
nfc_allocate_device(struct nfc_ops * ops,u32 supported_protocols,int tx_headroom,int tx_tailroom)1044 struct nfc_dev *nfc_allocate_device(struct nfc_ops *ops,
1045 				    u32 supported_protocols,
1046 				    int tx_headroom, int tx_tailroom)
1047 {
1048 	struct nfc_dev *dev;
1049 	int rc;
1050 
1051 	if (!ops->start_poll || !ops->stop_poll || !ops->activate_target ||
1052 	    !ops->deactivate_target || !ops->im_transceive)
1053 		return NULL;
1054 
1055 	if (!supported_protocols)
1056 		return NULL;
1057 
1058 	dev = kzalloc(sizeof(struct nfc_dev), GFP_KERNEL);
1059 	if (!dev)
1060 		return NULL;
1061 
1062 	rc = ida_simple_get(&nfc_index_ida, 0, 0, GFP_KERNEL);
1063 	if (rc < 0)
1064 		goto err_free_dev;
1065 	dev->idx = rc;
1066 
1067 	dev->dev.class = &nfc_class;
1068 	dev_set_name(&dev->dev, "nfc%d", dev->idx);
1069 	device_initialize(&dev->dev);
1070 
1071 	dev->ops = ops;
1072 	dev->supported_protocols = supported_protocols;
1073 	dev->tx_headroom = tx_headroom;
1074 	dev->tx_tailroom = tx_tailroom;
1075 	INIT_LIST_HEAD(&dev->secure_elements);
1076 
1077 	nfc_genl_data_init(&dev->genl_data);
1078 
1079 	dev->rf_mode = NFC_RF_NONE;
1080 
1081 	/* first generation must not be 0 */
1082 	dev->targets_generation = 1;
1083 
1084 	if (ops->check_presence) {
1085 		timer_setup(&dev->check_pres_timer, nfc_check_pres_timeout, 0);
1086 		INIT_WORK(&dev->check_pres_work, nfc_check_pres_work);
1087 	}
1088 
1089 	return dev;
1090 
1091 err_free_dev:
1092 	kfree(dev);
1093 
1094 	return NULL;
1095 }
1096 EXPORT_SYMBOL(nfc_allocate_device);
1097 
1098 /**
1099  * nfc_register_device - register a nfc device in the nfc subsystem
1100  *
1101  * @dev: The nfc device to register
1102  */
nfc_register_device(struct nfc_dev * dev)1103 int nfc_register_device(struct nfc_dev *dev)
1104 {
1105 	int rc;
1106 
1107 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
1108 
1109 	mutex_lock(&nfc_devlist_mutex);
1110 	nfc_devlist_generation++;
1111 	rc = device_add(&dev->dev);
1112 	mutex_unlock(&nfc_devlist_mutex);
1113 
1114 	if (rc < 0)
1115 		return rc;
1116 
1117 	rc = nfc_llcp_register_device(dev);
1118 	if (rc)
1119 		pr_err("Could not register llcp device\n");
1120 
1121 	rc = nfc_genl_device_added(dev);
1122 	if (rc)
1123 		pr_debug("The userspace won't be notified that the device %s was added\n",
1124 			 dev_name(&dev->dev));
1125 
1126 	dev->rfkill = rfkill_alloc(dev_name(&dev->dev), &dev->dev,
1127 				   RFKILL_TYPE_NFC, &nfc_rfkill_ops, dev);
1128 	if (dev->rfkill) {
1129 		if (rfkill_register(dev->rfkill) < 0) {
1130 			rfkill_destroy(dev->rfkill);
1131 			dev->rfkill = NULL;
1132 		}
1133 	}
1134 
1135 	return 0;
1136 }
1137 EXPORT_SYMBOL(nfc_register_device);
1138 
1139 /**
1140  * nfc_unregister_device - unregister a nfc device in the nfc subsystem
1141  *
1142  * @dev: The nfc device to unregister
1143  */
nfc_unregister_device(struct nfc_dev * dev)1144 void nfc_unregister_device(struct nfc_dev *dev)
1145 {
1146 	int rc;
1147 
1148 	pr_debug("dev_name=%s\n", dev_name(&dev->dev));
1149 
1150 	if (dev->rfkill) {
1151 		rfkill_unregister(dev->rfkill);
1152 		rfkill_destroy(dev->rfkill);
1153 	}
1154 
1155 	if (dev->ops->check_presence) {
1156 		device_lock(&dev->dev);
1157 		dev->shutting_down = true;
1158 		device_unlock(&dev->dev);
1159 		del_timer_sync(&dev->check_pres_timer);
1160 		cancel_work_sync(&dev->check_pres_work);
1161 	}
1162 
1163 	rc = nfc_genl_device_removed(dev);
1164 	if (rc)
1165 		pr_debug("The userspace won't be notified that the device %s "
1166 			 "was removed\n", dev_name(&dev->dev));
1167 
1168 	nfc_llcp_unregister_device(dev);
1169 
1170 	mutex_lock(&nfc_devlist_mutex);
1171 	nfc_devlist_generation++;
1172 	device_del(&dev->dev);
1173 	mutex_unlock(&nfc_devlist_mutex);
1174 }
1175 EXPORT_SYMBOL(nfc_unregister_device);
1176 
nfc_init(void)1177 static int __init nfc_init(void)
1178 {
1179 	int rc;
1180 
1181 	pr_info("NFC Core ver %s\n", VERSION);
1182 
1183 	rc = class_register(&nfc_class);
1184 	if (rc)
1185 		return rc;
1186 
1187 	rc = nfc_genl_init();
1188 	if (rc)
1189 		goto err_genl;
1190 
1191 	/* the first generation must not be 0 */
1192 	nfc_devlist_generation = 1;
1193 
1194 	rc = rawsock_init();
1195 	if (rc)
1196 		goto err_rawsock;
1197 
1198 	rc = nfc_llcp_init();
1199 	if (rc)
1200 		goto err_llcp_sock;
1201 
1202 	rc = af_nfc_init();
1203 	if (rc)
1204 		goto err_af_nfc;
1205 
1206 	return 0;
1207 
1208 err_af_nfc:
1209 	nfc_llcp_exit();
1210 err_llcp_sock:
1211 	rawsock_exit();
1212 err_rawsock:
1213 	nfc_genl_exit();
1214 err_genl:
1215 	class_unregister(&nfc_class);
1216 	return rc;
1217 }
1218 
nfc_exit(void)1219 static void __exit nfc_exit(void)
1220 {
1221 	af_nfc_exit();
1222 	nfc_llcp_exit();
1223 	rawsock_exit();
1224 	nfc_genl_exit();
1225 	class_unregister(&nfc_class);
1226 }
1227 
1228 subsys_initcall(nfc_init);
1229 module_exit(nfc_exit);
1230 
1231 MODULE_AUTHOR("Lauro Ramos Venancio <lauro.venancio@openbossa.org>");
1232 MODULE_DESCRIPTION("NFC Core ver " VERSION);
1233 MODULE_VERSION(VERSION);
1234 MODULE_LICENSE("GPL");
1235 MODULE_ALIAS_NETPROTO(PF_NFC);
1236 MODULE_ALIAS_GENL_FAMILY(NFC_GENL_NAME);
1237