/* * Copyright (C) 2015 Freescale Semiconductor, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef MXC_SIM_INTERFACE_H #define MXC_SIM_INTERFACE_H #define SIM_ATR_LENGTH_MAX 32 /* Raw ATR SIM_IOCTL_GET_ATR */ typedef struct { unsigned int size;/* length of ATR received */ unsigned char *atr_buffer;/* raw ATR string received */ int errval;/* The error vale reported to user space after completing ATR*/ } sim_atr_t; /* ISO7816-3 protocols */ #define SIM_PROTOCOL_T0 1 #define SIM_PROTOCOL_T1 2 /* Transfer types for SIM_IOCTL_XFER */ #define SIM_XFER_TYPE_TPDU 1 #define SIM_XFER_TYPE_PTS 2 typedef struct { unsigned int wwt; unsigned int cwt; unsigned int bwt; unsigned int bgt; unsigned int cgt; } sim_timing_t; /* Transfer data for SIM_IOCTL_XFER */ typedef struct { unsigned char *xmt_buffer; /* transmit buffer pointer */ int xmt_length;/* transmit buffer length */ int timeout;/* transfer timeout in milliseconds */ int errval;/* The error vale reported to user space after completing transmitting*/ } sim_xmt_t; typedef struct { unsigned char *rcv_buffer; /* receive buffer pointer */ int rcv_length; /* receive buffer length */ int timeout;/* transfer timeout in milliseconds */ int errval;/* The error vale reported to user space after receiving*/ } sim_rcv_t; typedef struct { unsigned char di; unsigned char fi; } sim_baud_t; /* Interface power states */ #define SIM_POWER_OFF (0) #define SIM_POWER_ON (1) /* Return values for SIM_IOCTL_GET_PRESENSE */ #define SIM_PRESENT_REMOVED (0) #define SIM_PRESENT_DETECTED (1) #define SIM_PRESENT_OPERATIONAL (2) /* The error value */ #define SIM_OK (0) #define SIM_ERROR_CWT (1 << 0) #define SIM_ERROR_BWT (1 << 1) #define SIM_ERROR_PARITY (1 << 2) #define SIM_ERROR_INVALID_TS (1 << 3) #define SIM_ERROR_FRAME (1 << 4) #define SIM_ERROR_ATR_TIMEROUT (1 << 5) #define SIM_ERROR_NACK_THRESHOLD (1 << 6) #define SIM_ERROR_BGT (1 << 7) #define SIM_ERROR_ATR_DELAY (1 << 8) /* Return values for SIM_IOCTL_GET_ERROR */ #define SIM_E_ACCESS (1) #define SIM_E_TPDUSHORT (2) #define SIM_E_PTSEMPTY (3) #define SIM_E_INVALIDXFERTYPE (4) #define SIM_E_INVALIDXMTLENGTH (5) #define SIM_E_INVALIDRCVLENGTH (6) #define SIM_E_NACK (7) #define SIM_E_TIMEOUT (8) #define SIM_E_NOCARD (9) #define SIM_E_PARAM_FI_INVALID (10) #define SIM_E_PARAM_DI_INVALID (11) #define SIM_E_PARAM_FBYD_WITHFRACTION (12) #define SIM_E_PARAM_FBYD_NOTDIVBY8OR12 (13) #define SIM_E_PARAM_DIVISOR_RANGE (14) #define SIM_E_MALLOC (15) #define SIM_E_IRQ (16) #define SIM_E_POWERED_ON (17) #define SIM_E_POWERED_OFF (18) /* ioctl encodings */ #define SIM_IOCTL_BASE (0xc0) #define SIM_IOCTL_GET_PRESENSE _IOR(SIM_IOCTL_BASE, 1, int) #define SIM_IOCTL_GET_ATR _IOR(SIM_IOCTL_BASE, 2, sim_atr_t) #define SIM_IOCTL_XMT _IOR(SIM_IOCTL_BASE, 3, sim_xmt_t) #define SIM_IOCTL_RCV _IOR(SIM_IOCTL_BASE, 4, sim_rcv_t) #define SIM_IOCTL_ACTIVATE _IO(SIM_IOCTL_BASE, 5) #define SIM_IOCTL_DEACTIVATE _IO(SIM_IOCTL_BASE, 6) #define SIM_IOCTL_WARM_RESET _IO(SIM_IOCTL_BASE, 7) #define SIM_IOCTL_COLD_RESET _IO(SIM_IOCTL_BASE, 8) #define SIM_IOCTL_CARD_LOCK _IO(SIM_IOCTL_BASE, 9) #define SIM_IOCTL_CARD_EJECT _IO(SIM_IOCTL_BASE, 10) #define SIM_IOCTL_SET_PROTOCOL _IOR(SIM_IOCTL_BASE, 11, unsigned int) #define SIM_IOCTL_SET_TIMING _IOR(SIM_IOCTL_BASE, 12, sim_timing_t) #define SIM_IOCTL_SET_BAUD _IOR(SIM_IOCTL_BASE, 13, sim_baud_t) #define SIM_IOCTL_WAIT _IOR(SIM_IOCTL_BASE, 14, unsigned int) #endif