Hi I am trying to get the mxc_sim_test.c t_program to execute correctly but without success . I am trying to talk to a MIFARE_SAM_AV2 with necessary T1 protocol.
I get as far as the getting atr output:
atr[0]= 0x3b atr[1]= 0xdf atr[2]= 0x18 atr[3]= 0xff atr[4]= 0x81 atr[5]= 0xf1 atr[6]= 0xfe atr[7]= 0x43 atr[8]= 0x0 atr[9]= 0x3f atr[10]= 0x3 atr[11]= 0x83 atr[12]= 0x4d atr[13]= 0x49 atr[14]= 0x46 atr[15]= 0x41 atr[16]= 0x52 atr[17]= 0x45 atr[18]= 0x20 atr[19]= 0x50 atr[20]= 0x6c atr[21]= 0x75 atr[22]= 0x73 atr[23]= 0x20 atr[24]= 0x53 atr[25]= 0x41 atr[26]= 0x4d atr[27]= 0x3b
However when I try and run the APDU transcieve commands later in the program I get a hang on receive.
I suspect that I am not filling in the values correctly from the ATR response to the parameter data blocks :
I cannot easily see how to map the ATR vales to the overwrite the defaults above (which do not work for me). Can someone help me with the values I need to edit in? An example of a T1 equivalent of the
On online parser gives the following output and some of the values eg bwt= 4 cwt=3. As for the other values I am totally lost.
Parsing ATR:
| TS = 0x3B | Direct Convention | 
|---|---|
| T0 = 0xDF | Y(1): b1101, K: 15 (historical bytes) | 
| TA(1) = 0x18 | Fi=372, Di=12, 31 cycles/ETU (129032 bits/s at 4.00 MHz, 161290 bits/s for fMax=5 MHz) | 
| TC(1) = 0xFF | Extra guard time: 255 (special value) | 
| TD(1) = 0x81 | Y(i+1) = b1000, Protocol T=1 | 
| ---- | |
| TD(2) = 0xF1 | Y(i+1) = b1111, Protocol T=1 | 
| ---- | |
| TA(3) = 0xFE | IFSC: 254 | 
| TB(3) = 0x43 | Block Waiting Integer: 4 - Character Waiting Integer: 3 | 
| TC(3) = 0x00 | Error detection code: LRC | 
| TD(3) = 0x3F | Y(i+1) = b0011, Protocol T=15 | 
| ---- | |
| TA(4) = 0x03 | Clock stop: not supported - Class accepted by the card: (3G) A 5V B 3V | 
| TB(4) = 0x83 | RFU | 
| ---- | |
| Historical bytes | 4D 49 46 41 52 45 20 50 6C 75 73 20 53 41 4D | 
| Category indicator byte: 0x4D | (proprietary format) "IFARE Plus SAM" | 
21/03/19 Update on Progress
=========================
we have made some progress on this.
1. The mxc_test_sim.c program is an example of T0 transmission only. Really needed a T1 example talking to the IMX_SIM driver to avoid much of the pain.
2. Below is some test source we have created that shows reception of an ATR, the transmission of a PPS message and reply, setting of timer values from values taken from ATR and a T1 frame. In this case a request to Get Version from an onboard MIFARE SAM AV1 . The T1 command requires NAD, Protocol and frame data length bytes prefixing the command buffer. Also the user must compute the LRC (not appended by the driver). A 32 byte version response
3. Driver does not support flow control/chaining of T1 as far we can see. It would be helpful if someone at NXP would point us to source of a basic C implementation of T1 that we can use that makes use of this driver.
4. The timing values that we used may or may not be optiimal. It would be useful to get feedback on this.
See attached test program/output
root@mdb-4355642552:~# ./SamIfTest
ReaderStart: 0 
ColdReset: 0 
ATR result 0 Size: 28 
SEND PPSGET PPS lenght 4 PPS[0]: 0xff PPS[1]: 0x11 PPS[2]: 0x1 PPS[3]: 0xef
errval send 0 
errval receive 0 
 GV[0]: 0x0 GV[1]: 0x20 GV[2]: 0x20 GV[3]: 0x4 GV[4]: 0x1 GV[5]: 0x1 GV[6]: 0x3 GV[7]: 0x2 GV[8]: 0x28 GV[9]: 0x1 GV[10]: 0x4 GV[11]: 0x1 GV[12]: 0x1 GV[13]: 0x3 GV[14]: 0x2 GV[15]: 0x28 GV[16]: 0x1 GV[17]: 0x4 GV[18]: 0x12 GV[19]: 0x3e GV[20]: 0x92 GV[21]: 0x3c GV[22]: 0x50 GV[23]: 0x80 GV[24]: 0x98 GV[25]: 0x76 GV[26]: 0x58 GV[27]: 0x0 GV[28]: 0x0 GV[29]: 0x19 GV[30]: 0x7 GV[31]: 0x11 GV[32]: 0x0 GV[33]: 0xa1 GV[34]: 0x90 GV[35]: 0xde
receive lenght 36 
root@mdb-4355642552:~# 
I have resolved this.
1. it needed a minor update to imx_sim driver.
2. Adjusted baud rate to 3.5 mhz
3. In terms of general operation with a t1 protocol device I incorporated opensc. I could use the proto-t1.c module unmodified. All that was needed was to update the commands.c module to make the IOCTL driver read and write commands directly by rewriting CCID_Transmit.
Hi Arthur,
We are also working on T=1 protocol, Could you please help us with your imx_sim changes to fix T1 protocol issue.
Hi Arthur,
Thank for your effort. It really help me a lot.
Now I'm following your step try to integrate proto-t1.c to support general operation for T=1.
But I'm stuck in rewriting CCID_Transmit and CCID_Receive.
Can you point me some direction how to rewrite this two function with mxc_sim driver?
Arthur,
is it possible to see your changes to commands.c module of opensc? I'm considering a new openct driver, so that opensc would be able to use CCID_Transmit without modification, as well as making mcx_sim compatible with any pcsc-lite consumers, such as for example gpshell, etc.
It would be really helpful if I can see what you've already done for opensc integration (or at least a little bit more sample code + mxc_sim driver patch that you mention in your post)
Hi valery
Can you resend your request to arthurm@l5systems.com..
I have managed to look out the files you asked about. We would be
interested to get any improvements you make.
Br Arthur
 
					
				
		
 diegoadrian
		
			diegoadrian
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Hello,
Unfortunately, we cannot help you with this since the MIFARE SAM V2 is not supported by us, you will need to go with your sales representative or your DFAE, they will guide with someone that could help you. I apologize for the inconveniences this could give you.
Best regards,
Diego.
