1*1ccea77eSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */ 28b8d2e08SEric Lapuyade /* 38b8d2e08SEric Lapuyade * Copyright (C) 2012 Intel Corporation. All rights reserved. 48b8d2e08SEric Lapuyade */ 58b8d2e08SEric Lapuyade 68b8d2e08SEric Lapuyade #ifndef __LOCAL_HCI_H 78b8d2e08SEric Lapuyade #define __LOCAL_HCI_H 88b8d2e08SEric Lapuyade 9b5faa648SEric Lapuyade #include <net/nfc/hci.h> 10b5faa648SEric Lapuyade 118b8d2e08SEric Lapuyade struct gate_pipe_map { 128b8d2e08SEric Lapuyade u8 gate; 138b8d2e08SEric Lapuyade u8 pipe; 148b8d2e08SEric Lapuyade }; 158b8d2e08SEric Lapuyade 168b8d2e08SEric Lapuyade struct hcp_message { 178b8d2e08SEric Lapuyade u8 header; /* type -cmd,evt,rsp- + instruction */ 188b8d2e08SEric Lapuyade u8 data[]; 198b8d2e08SEric Lapuyade } __packed; 208b8d2e08SEric Lapuyade 218b8d2e08SEric Lapuyade struct hcp_packet { 228b8d2e08SEric Lapuyade u8 header; /* cbit+pipe */ 238b8d2e08SEric Lapuyade struct hcp_message message; 248b8d2e08SEric Lapuyade } __packed; 258b8d2e08SEric Lapuyade 268b8d2e08SEric Lapuyade struct hcp_exec_waiter { 278b8d2e08SEric Lapuyade wait_queue_head_t *wq; 288b8d2e08SEric Lapuyade bool exec_complete; 298b8d2e08SEric Lapuyade int exec_result; 308b8d2e08SEric Lapuyade struct sk_buff *result_skb; 318b8d2e08SEric Lapuyade }; 328b8d2e08SEric Lapuyade 338b8d2e08SEric Lapuyade struct hci_msg { 348b8d2e08SEric Lapuyade struct list_head msg_l; 358b8d2e08SEric Lapuyade struct sk_buff_head msg_frags; 368b8d2e08SEric Lapuyade bool wait_response; 37b5faa648SEric Lapuyade data_exchange_cb_t cb; 388b8d2e08SEric Lapuyade void *cb_context; 398b8d2e08SEric Lapuyade unsigned long completion_delay; 408b8d2e08SEric Lapuyade }; 418b8d2e08SEric Lapuyade 428b8d2e08SEric Lapuyade struct hci_create_pipe_params { 438b8d2e08SEric Lapuyade u8 src_gate; 448b8d2e08SEric Lapuyade u8 dest_host; 458b8d2e08SEric Lapuyade u8 dest_gate; 468b8d2e08SEric Lapuyade } __packed; 478b8d2e08SEric Lapuyade 488b8d2e08SEric Lapuyade struct hci_create_pipe_resp { 498b8d2e08SEric Lapuyade u8 src_host; 508b8d2e08SEric Lapuyade u8 src_gate; 518b8d2e08SEric Lapuyade u8 dest_host; 528b8d2e08SEric Lapuyade u8 dest_gate; 538b8d2e08SEric Lapuyade u8 pipe; 548b8d2e08SEric Lapuyade } __packed; 558b8d2e08SEric Lapuyade 56615b524aSChristophe Ricard struct hci_delete_pipe_noti { 57615b524aSChristophe Ricard u8 pipe; 58615b524aSChristophe Ricard } __packed; 59615b524aSChristophe Ricard 60615b524aSChristophe Ricard struct hci_all_pipe_cleared_noti { 61615b524aSChristophe Ricard u8 host; 62615b524aSChristophe Ricard } __packed; 63615b524aSChristophe Ricard 648b8d2e08SEric Lapuyade #define NFC_HCI_FRAGMENT 0x7f 658b8d2e08SEric Lapuyade 668b8d2e08SEric Lapuyade #define HCP_HEADER(type, instr) ((((type) & 0x03) << 6) | ((instr) & 0x3f)) 678b8d2e08SEric Lapuyade #define HCP_MSG_GET_TYPE(header) ((header & 0xc0) >> 6) 688b8d2e08SEric Lapuyade #define HCP_MSG_GET_CMD(header) (header & 0x3f) 698b8d2e08SEric Lapuyade 708b8d2e08SEric Lapuyade int nfc_hci_hcp_message_tx(struct nfc_hci_dev *hdev, u8 pipe, 718b8d2e08SEric Lapuyade u8 type, u8 instruction, 728b8d2e08SEric Lapuyade const u8 *payload, size_t payload_len, 73b5faa648SEric Lapuyade data_exchange_cb_t cb, void *cb_context, 748b8d2e08SEric Lapuyade unsigned long completion_delay); 758b8d2e08SEric Lapuyade 768b8d2e08SEric Lapuyade void nfc_hci_hcp_message_rx(struct nfc_hci_dev *hdev, u8 pipe, u8 type, 778b8d2e08SEric Lapuyade u8 instruction, struct sk_buff *skb); 788b8d2e08SEric Lapuyade 798b8d2e08SEric Lapuyade /* HCP headers */ 808b8d2e08SEric Lapuyade #define NFC_HCI_HCP_PACKET_HEADER_LEN 1 818b8d2e08SEric Lapuyade #define NFC_HCI_HCP_MESSAGE_HEADER_LEN 1 828b8d2e08SEric Lapuyade #define NFC_HCI_HCP_HEADER_LEN 2 838b8d2e08SEric Lapuyade 848b8d2e08SEric Lapuyade /* HCP types */ 858b8d2e08SEric Lapuyade #define NFC_HCI_HCP_COMMAND 0x00 868b8d2e08SEric Lapuyade #define NFC_HCI_HCP_EVENT 0x01 878b8d2e08SEric Lapuyade #define NFC_HCI_HCP_RESPONSE 0x02 888b8d2e08SEric Lapuyade 898b8d2e08SEric Lapuyade /* Generic commands */ 908b8d2e08SEric Lapuyade #define NFC_HCI_ANY_SET_PARAMETER 0x01 918b8d2e08SEric Lapuyade #define NFC_HCI_ANY_GET_PARAMETER 0x02 928b8d2e08SEric Lapuyade #define NFC_HCI_ANY_OPEN_PIPE 0x03 938b8d2e08SEric Lapuyade #define NFC_HCI_ANY_CLOSE_PIPE 0x04 948b8d2e08SEric Lapuyade 958b8d2e08SEric Lapuyade /* Reader RF commands */ 968b8d2e08SEric Lapuyade #define NFC_HCI_WR_XCHG_DATA 0x10 978b8d2e08SEric Lapuyade 988b8d2e08SEric Lapuyade /* Admin commands */ 998b8d2e08SEric Lapuyade #define NFC_HCI_ADM_CREATE_PIPE 0x10 1008b8d2e08SEric Lapuyade #define NFC_HCI_ADM_DELETE_PIPE 0x11 1018b8d2e08SEric Lapuyade #define NFC_HCI_ADM_NOTIFY_PIPE_CREATED 0x12 1028b8d2e08SEric Lapuyade #define NFC_HCI_ADM_NOTIFY_PIPE_DELETED 0x13 1038b8d2e08SEric Lapuyade #define NFC_HCI_ADM_CLEAR_ALL_PIPE 0x14 1048b8d2e08SEric Lapuyade #define NFC_HCI_ADM_NOTIFY_ALL_PIPE_CLEARED 0x15 1058b8d2e08SEric Lapuyade 1068b8d2e08SEric Lapuyade /* Generic responses */ 1078b8d2e08SEric Lapuyade #define NFC_HCI_ANY_OK 0x00 1088b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_NOT_CONNECTED 0x01 1098b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_CMD_PAR_UNKNOWN 0x02 1108b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_NOK 0x03 1118b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_PIPES_FULL 0x04 1128b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_REG_PAR_UNKNOWN 0x05 1138b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_PIPE_NOT_OPENED 0x06 1148b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_CMD_NOT_SUPPORTED 0x07 1158b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_INHIBITED 0x08 1168b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_TIMEOUT 0x09 1178b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_REG_ACCESS_DENIED 0x0a 1188b8d2e08SEric Lapuyade #define NFC_HCI_ANY_E_PIPE_ACCESS_DENIED 0x0b 1198b8d2e08SEric Lapuyade 1208b8d2e08SEric Lapuyade #endif /* __LOCAL_HCI_H */ 121