Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

NFC: Export a new attribute nfcid1 in target info

The nfcid1 is the NFC-A identifier.
It is exported as an attribute of the target info
(returned as a response to NFC_CMD_GET_TARGET).

Signed-off-by: Ilan Elias <ilane@ti.com>
Acked-by: Samuel Ortiz <sameo@linux.intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>

authored by

Ilan Elias and committed by
John W. Linville
288e0713 9931df26

+14
+2
include/linux/nfc.h
··· 88 88 * @NFC_ATTR_TARGET_SENS_RES: NFC-A targets extra information such as NFCID 89 89 * @NFC_ATTR_TARGET_SEL_RES: NFC-A targets extra information (useful if the 90 90 * target is not NFC-Forum compliant) 91 + * @NFC_ATTR_TARGET_NFCID1: NFC-A targets identifier, max 10 bytes 91 92 * @NFC_ATTR_COMM_MODE: Passive or active mode 92 93 * @NFC_ATTR_RF_MODE: Initiator or target 93 94 */ ··· 100 99 NFC_ATTR_TARGET_INDEX, 101 100 NFC_ATTR_TARGET_SENS_RES, 102 101 NFC_ATTR_TARGET_SEL_RES, 102 + NFC_ATTR_TARGET_NFCID1, 103 103 NFC_ATTR_COMM_MODE, 104 104 NFC_ATTR_RF_MODE, 105 105 /* private: internal use only */
+3
include/net/nfc/nfc.h
··· 65 65 66 66 #define NFC_TARGET_IDX_ANY -1 67 67 #define NFC_MAX_GT_LEN 48 68 + #define NFC_MAX_NFCID1_LEN 10 68 69 69 70 struct nfc_target { 70 71 u32 idx; 71 72 u32 supported_protocols; 72 73 u16 sens_res; 73 74 u8 sel_res; 75 + u8 nfcid1_len; 76 + u8 nfcid1[NFC_MAX_NFCID1_LEN]; 74 77 }; 75 78 76 79 struct nfc_genl_data {
+6
net/nfc/nci/ntf.c
··· 154 154 155 155 nfc_tgt.sens_res = ntf->rf_tech_specific_params.nfca_poll.sens_res; 156 156 nfc_tgt.sel_res = ntf->rf_tech_specific_params.nfca_poll.sel_res; 157 + nfc_tgt.nfcid1_len = ntf->rf_tech_specific_params.nfca_poll.nfcid1_len; 158 + if (nfc_tgt.nfcid1_len > 0) { 159 + memcpy(nfc_tgt.nfcid1, 160 + ntf->rf_tech_specific_params.nfca_poll.nfcid1, 161 + nfc_tgt.nfcid1_len); 162 + } 157 163 158 164 if (!(nfc_tgt.supported_protocols & ndev->poll_prots)) { 159 165 pr_debug("the target found does not have the desired protocol\n");
+3
net/nfc/netlink.c
··· 67 67 target->supported_protocols); 68 68 NLA_PUT_U16(msg, NFC_ATTR_TARGET_SENS_RES, target->sens_res); 69 69 NLA_PUT_U8(msg, NFC_ATTR_TARGET_SEL_RES, target->sel_res); 70 + if (target->nfcid1_len > 0) 71 + NLA_PUT(msg, NFC_ATTR_TARGET_NFCID1, target->nfcid1_len, 72 + target->nfcid1); 70 73 71 74 return genlmsg_end(msg, hdr); 72 75