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