]> git.baikalelectronics.ru Git - kernel.git/commitdiff
NFC: hci: Add cmd_received handler
authorChristophe Ricard <christophe.ricard@gmail.com>
Tue, 27 Jan 2015 00:18:15 +0000 (01:18 +0100)
committerSamuel Ortiz <sameo@linux.intel.com>
Tue, 27 Jan 2015 23:03:34 +0000 (00:03 +0100)
When a command is received, it is sometime needed to let the CLF driver do
some additional operations. (ex: count remaining pipe notification...)

Signed-off-by: Christophe Ricard <christophe-h.ricard@st.com>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
include/net/nfc/hci.h
net/nfc/hci/core.c

index 1d1fd2b98f1e0f417f6cfaf8dbb7c12db179a775..ab672b537dd4618dc25c31d1e10f400c96284fd2 100644 (file)
@@ -53,6 +53,8 @@ struct nfc_hci_ops {
                              struct nfc_target *target);
        int (*event_received)(struct nfc_hci_dev *hdev, u8 pipe, u8 event,
                              struct sk_buff *skb);
+       void (*cmd_received)(struct nfc_hci_dev *hdev, u8 pipe, u8 cmd,
+                           struct sk_buff *skb);
        int (*fw_download)(struct nfc_hci_dev *hdev, const char *firmware_name);
        int (*discover_se)(struct nfc_hci_dev *dev);
        int (*enable_se)(struct nfc_hci_dev *dev, u32 se_idx);
@@ -230,6 +232,12 @@ void nfc_hci_reset_pipes_per_host(struct nfc_hci_dev *hdev, u8 host);
 #define NFC_HCI_EVT_POST_DATA                  0x02
 #define NFC_HCI_EVT_HOT_PLUG                   0x03
 
+/* Generic commands */
+#define NFC_HCI_ANY_SET_PARAMETER      0x01
+#define NFC_HCI_ANY_GET_PARAMETER      0x02
+#define NFC_HCI_ANY_OPEN_PIPE          0x03
+#define NFC_HCI_ANY_CLOSE_PIPE         0x04
+
 /* Reader RF gates events */
 #define NFC_HCI_EVT_READER_REQUESTED   0x10
 #define NFC_HCI_EVT_END_OPERATION      0x11
index a664a67dff1ca6a7d42876de480234dfaa9e4b28..6e061da2258a8bd32f80f585aaaf7e951180b7d3 100644 (file)
@@ -249,6 +249,9 @@ void nfc_hci_cmd_received(struct nfc_hci_dev *hdev, u8 pipe, u8 cmd,
                break;
        }
 
+       if (hdev->ops->cmd_received)
+               hdev->ops->cmd_received(hdev, pipe, cmd, skb);
+
 exit:
        nfc_hci_hcp_message_tx(hdev, pipe, NFC_HCI_HCP_RESPONSE,
                               status, NULL, 0, NULL, NULL, 0);