From: iceman1001 <iceman@iuse.se>
Date: Thu, 2 Feb 2017 18:15:36 +0000 (+0100)
Subject: CHG:  'lf cotag demod'  - now finds FC/CN  Thanks to @marshmellow42
X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/commitdiff_plain/a330987de11ccc43c30eb40afe6d15abf32ffcf2?ds=inline

CHG:  'lf cotag demod'  - now finds FC/CN  Thanks to @marshmellow42
CHG:  'lf search' - now detects COTAG
---

diff --git a/armsrc/lfsampling.c b/armsrc/lfsampling.c
index 841bfab8..def7431d 100644
--- a/armsrc/lfsampling.c
+++ b/armsrc/lfsampling.c
@@ -371,8 +371,8 @@ uint32_t doCotagAcquisitionManchester() {
 	uint8_t *dest = BigBuf_get_addr();
 	uint16_t bufsize = BigBuf_max_traceLen();
 	
-	if ( bufsize > 320 )
-		bufsize = 320;
+	if ( bufsize > COTAG_BITS )
+		bufsize = COTAG_BITS;
 
 	dest[0] = 0;	
 	uint8_t sample = 0, firsthigh = 0, firstlow = 0; 
diff --git a/client/cmdlf.c b/client/cmdlf.c
index 31e747d3..8931fc75 100644
--- a/client/cmdlf.c
+++ b/client/cmdlf.c
@@ -1116,6 +1116,14 @@ int CmdLFfind(const char *Cmd) {
 		PrintAndLog("\nValid Presco ID Found!");
 		return 1;
 	}
+	// ICEMAN;  always call save_restorGB for COTAG. Will break graphbuffer
+	save_restoreGB(1)
+	ans=CmdCOTAGRead("");
+	if (ans>0){
+		PrintAndLog("\nValid COTAG ID Found!");
+		return 1;
+	}
+	save_restoreGB(0)
 	// TIdemod?
 
 /*	
@@ -1126,7 +1134,6 @@ int CmdLFfind(const char *Cmd) {
 		}
 	}
 */
-
 	PrintAndLog("\nNo Known Tags Found!\n");
 	if (testRaw=='u' || testRaw=='U'){
 		//test unknown tag formats (raw mode)
diff --git a/client/cmdlfcotag.c b/client/cmdlfcotag.c
index ef935bb0..3c1c3caa 100644
--- a/client/cmdlfcotag.c
+++ b/client/cmdlfcotag.c
@@ -8,7 +8,7 @@
 // Low frequency COTAG commands
 //-----------------------------------------------------------------------------
 #include "cmdlfcotag.h"  // COTAG function declarations
- 
+
 static int CmdHelp(const char *Cmd);
 
 int usage_lf_cotag_read(void){
@@ -24,8 +24,37 @@ int usage_lf_cotag_read(void){
 	PrintAndLog("        lf cotag read 1");
 	return 0;
 }
+
+// COTAG demod should be able to use GraphBuffer,
+// when data load samples
 int CmdCOTAGDemod(const char *Cmd) {
-	return 0;
+
+	uint8_t bits[COTAG_BITS] = {0};
+	size_t bitlen = COTAG_BITS;
+	memcpy(bits, DemodBuffer, COTAG_BITS);
+	
+	int err = manrawdecode(bits, &bitlen, 1);
+	if (err){
+		if (g_debugMode) PrintAndLog("DEBUG: Error - COTAG too many errors: %d", err);
+		return -1;
+	}
+
+	setDemodBuf(bits, bitlen, 0);
+
+	//got a good demod
+	uint16_t cn = bytebits_to_byteLSBF(bits+1, 16);
+	uint32_t fc = bytebits_to_byteLSBF(bits+1+16, 8);
+	
+	/*
+	fc 161:   1010 0001 -> LSB 1000 0101
+	cn 33593  1000 0011 0011 1001 -> LSB 1001 1100 1100 0001
+        cccc cccc cccc cccc                     ffffffff
+	  0 1001 1100 1100 0001 1000 0101 0000 0000 100001010000000001111011100000011010000010000000000000000000000000000000000000000000000000000000100111001100000110000101000
+        1001 1100 1100 0001                     10000101                                                                                         
+	*/
+	//PrintAndLog("COTAG Found: FC %u, CN: %u Raw: %08X%08X%08X", fc, cn); //, raw1 ,raw2, raw3);
+	PrintAndLog("COTAG Found: FC %u, CN: %u", fc, cn); 
+	return 1;
 }
 
 // When reading a COTAG.
@@ -36,8 +65,7 @@ int CmdCOTAGRead(const char *Cmd) {
 	
 	if (Cmd[0] == 'h' || Cmd[0] == 'H') return usage_lf_cotag_read();
 	
-	uint8_t bits[320] = {0};
-	uint32_t rawsignal = 0;
+	uint32_t rawsignal = 1;
 	sscanf(Cmd, "%u", &rawsignal);
  
 	UsbCommand c = {CMD_COTAG, {rawsignal, 0, 0}};
@@ -45,7 +73,7 @@ int CmdCOTAGRead(const char *Cmd) {
 	SendCommand(&c);
 	if ( !WaitForResponseTimeout(CMD_ACK, NULL, 7000) ) {
 		PrintAndLog("command execution time out");
-		return 1;	
+		return -1;	
 	}
 	
 	switch ( rawsignal ){
@@ -56,24 +84,14 @@ int CmdCOTAGRead(const char *Cmd) {
 			getSamples("", true); break;
 		}
 		case 1: {
-			GetFromBigBuf(bits, sizeof(bits), 0);
+			GetFromBigBuf(DemodBuffer, COTAG_BITS, 0);
+			DemodBufferLen = COTAG_BITS;
 			UsbCommand response;
-			if ( !WaitForResponseTimeout(CMD_ACK, &response, 500) ) {
-				if (g_debugMode) PrintAndLog("timeout while waiting for reply.");
-				return 1;
-			}
-			
-			size_t size = sizeof(bits);
-			int err = manrawdecode(bits, &size, 1);
-			if (err){
-				if (g_debugMode) PrintAndLog("DEBUG: Error - COTAG too many errors: %d", err);
-				return 0;
+			if ( !WaitForResponseTimeout(CMD_ACK, &response, 1000) ) {
+				PrintAndLog("timeout while waiting for reply.");
+				return -1;
 			}
-			PrintAndLog("%s", sprint_bin(bits, size));
-			setDemodBuf(bits, size, 0);
-			
-			// CmdCOTAGDemod();
-			break;
+			return CmdCOTAGDemod("");
 		}
 	}	
 	return 0;
diff --git a/client/cmdlfcotag.h b/client/cmdlfcotag.h
index ab808b40..265f60d9 100644
--- a/client/cmdlfcotag.h
+++ b/client/cmdlfcotag.h
@@ -11,14 +11,18 @@
 #ifndef CMDLFCOTAG_H__
 #define CMDLFCOTAG_H__
 
+#include "proxmark3.h"  // Definitions, USB controls, COTAG_BITS
 #include "util.h"       // FALSE / TRUE
-#include "proxmark3.h"  // Definitions, USB controls, etc
 #include "cmddata.h"	// getSamples
 #include "cmdparser.h"  // CmdsParse, CmdsHelp
 #include "cmdmain.h"
 #include "ui.h"			// PrintAndLog
 #include "cmdlf.h"		// Setconfig 
 
+#ifndef COTAG_BITS
+#define COTAG_BITS 320
+#endif
+
 int CmdLFCOTAG(const char *Cmd);
 int CmdCOTAGRead(const char *Cmd);
 int CmdCOTAGDemod(const char *Cmd);
diff --git a/client/cmdlfjablotron.c b/client/cmdlfjablotron.c
index 95fe2922..f1da737d 100644
--- a/client/cmdlfjablotron.c
+++ b/client/cmdlfjablotron.c
@@ -105,8 +105,7 @@ int CmdJablotronDemod(const char *Cmd) {
 	uint64_t rawid = bytebits_to_byte(DemodBuffer+16, 40);
 	uint64_t id = getJablontronCardId(rawid);
 
-	PrintAndLog("Jablotron Tag Found: Card ID %u", id);
-	PrintAndLog("Raw: %08X%08X", raw1 ,raw2);
+	PrintAndLog("Jablotron Tag Found: Card ID %u  :: Raw: %08X%08X", id, raw1 ,raw2);
 
 	uint8_t chksum = raw2 & 0xFF;
 	PrintAndLog("Checksum: %02X [%s]",
diff --git a/include/proxmark3.h b/include/proxmark3.h
index 4a59636e..4fb1a30b 100644
--- a/include/proxmark3.h
+++ b/include/proxmark3.h
@@ -64,6 +64,10 @@
 #define TRUE 1
 #define FALSE 0
 
+#ifndef COTAG_BITS
+#define COTAG_BITS 320
+#endif
+
 //#define PACKED __attribute__((__packed__))
 
 #define LED_A_ON()		HIGH(GPIO_LED_A)