Переход в новую организацию
This commit is contained in:
		
						commit
						3a8c8a3d84
					
				|  | @ -0,0 +1,46 @@ | |||
| //
 | ||||
| // Created by xemon on 09.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #ifndef GSMAT_GSMATCOMMANDRESULT_H | ||||
| #define GSMAT_GSMATCOMMANDRESULT_H | ||||
| 
 | ||||
| #include "SerialPort.h" | ||||
| #include "stddef.h" | ||||
| 
 | ||||
| typedef enum { | ||||
|     AT_BUSY = -3, | ||||
|     AT_TIMEOUT = -2, | ||||
|     AT_NONE = -1, | ||||
|     AT_ERROR = 0, | ||||
|     AT_OK = 1, | ||||
| } AtCommandResult; | ||||
| 
 | ||||
| typedef struct { | ||||
|     size_t len; | ||||
|     char *data; | ||||
|     size_t limit; | ||||
| } tAtBuffer; | ||||
| 
 | ||||
| typedef struct { | ||||
|     void *env; | ||||
| 
 | ||||
|     void (*process)(void *env, tAtBuffer *buffer); | ||||
| 
 | ||||
| } tAtCmdUrcProcessor; | ||||
| 
 | ||||
| #define AtCmdUrcProcessor_Process(ENV, BUFF) (ENV)->process((ENV)->env,BUFF) | ||||
| 
 | ||||
| typedef struct { | ||||
|     tSerialPortIO *io; | ||||
| 
 | ||||
|     tAtBuffer txBuffer; | ||||
|     tAtBuffer rxBuffer; | ||||
| 
 | ||||
|     uint32_t stdTxTimeout; | ||||
|     uint32_t stdRxTimeout; | ||||
| 
 | ||||
|     tAtCmdUrcProcessor urcProcessor; | ||||
| } tAtCmd; | ||||
| 
 | ||||
| #endif //GSMAT_GSMATCOMMANDRESULT_H
 | ||||
|  | @ -0,0 +1,46 @@ | |||
| //
 | ||||
| // Created by xemon on 07.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #ifndef GSMCOMMONAT_GSMCOMMONAT_H | ||||
| #define GSMCOMMONAT_GSMCOMMONAT_H | ||||
| 
 | ||||
| #include "stdint.h" | ||||
| #include "stddef.h" | ||||
| #include "SerialPort.h" | ||||
| #include "AtCmdBase.h" | ||||
| 
 | ||||
| void AtCmdInit( | ||||
|         tAtCmd *env, | ||||
|         tSerialPortIO *io, | ||||
|         uint8_t *txBuffer, | ||||
|         size_t txBufferSize, | ||||
|         uint8_t *rxBuffer, | ||||
|         size_t rxBufferSize, | ||||
|         uint32_t stdTxTimeout, | ||||
|         uint32_t stdRxTimeout | ||||
| ); | ||||
| 
 | ||||
| AtCommandResult AtCmd(tAtCmd *env); | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitOk(tAtCmd *env, uint32_t retryInterval, uint32_t timeout); | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitPrefix(tAtCmd *env, uint16_t timeout, char *line, size_t lineLen); | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitChar(tAtCmd *env, uint16_t timeout, char line); | ||||
| 
 | ||||
| #define AtCmdWaitPrefixStatic(ENV, TIMEOUT, STR) AtCmdWaitPrefix(ENV,TIMEOUT,STR, sizeof(STR)-1) | ||||
| 
 | ||||
| void AtCmdSetUrcProcessor(tAtCmd *env, void *urcProcEnv, void *urcProcFunc); | ||||
| 
 | ||||
| void AtCmdClearUrcProcessor(tAtCmd *env); | ||||
| 
 | ||||
| void AtCmdProcessUnresolvedLine(tAtCmd *env); | ||||
| 
 | ||||
| void AtCmdProcessUnresolvedLines(tAtCmd *env); | ||||
| 
 | ||||
| #include "AtGsmListCurrentCalls.h" | ||||
| 
 | ||||
| #include "AtGsmErrorLogLevel.h" | ||||
| 
 | ||||
| #endif //GSMCOMMONAT_GSMCOMMONAT_H
 | ||||
|  | @ -0,0 +1,62 @@ | |||
| //
 | ||||
| // Created by xemon on 07.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #ifndef GSMCOMMONAT_GSMCOMMONATPRIVATE_H | ||||
| #define GSMCOMMONAT_GSMCOMMONATPRIVATE_H | ||||
| 
 | ||||
| #include "AtCmdCommon.h" | ||||
| #include "AsciiStringAssmeblingUtils.h" | ||||
| 
 | ||||
| void AtCmdPrepare(tAtCmd *env); | ||||
| 
 | ||||
| #define AtCmdSendStatic(env, STR)  SerialPortTransmit((env)->io, (uint8_t *) (STR), sizeof (STR)-1, (env)->stdTxTimeout) | ||||
| #define AtCmdSend(env, STR, LEN)  SerialPortTransmit((env)->io, (uint8_t *) (STR), LEN, (env)->stdTxTimeout) | ||||
| 
 | ||||
| 
 | ||||
| //tx buffer operations
 | ||||
| #define AtCmdTxPrint(ENV, FMT, ...)  debug_printf((ENV)->io, FMT, ##__VA_ARGS__); | ||||
| 
 | ||||
| #define AtCmdTxClear(env)  vAsciiStringClean((env)->txBuffer.data, &(env)->txBuffer.len) | ||||
| #define AtCmdTxAdd(env, STR, LEN)  vAsciiStringAdd((env)->txBuffer.data, &(env)->txBuffer.len, STR,LEN) | ||||
| #define AtCmdTxAddStatic(env, STR)  vAsciiStringAddStatic((env)->txBuffer.data, &(env)->txBuffer.len, STR) | ||||
| #define AtCmdTxAddByteHex(env, BYTE) vAsciiStringAddByteAsHex((env)->txBuffer.data, &(env)->txBuffer.len, BYTE) | ||||
| #define AtCmdTxAddChar(env, CHAR) vAsciiStringAddChar((env)->txBuffer.data, &(env)->txBuffer.len, CHAR) | ||||
| #define AtCmdTxAddDecimalInt(env, INT, DIGITS) vAsciiStringAddDecimalInt((env)->txBuffer.data, &(env)->txBuffer.len, INT,DIGITS) | ||||
| #define AtCmdTxAddDecimalIntWithLimit(env, INT, DIGITS) vAsciiStringAddDecimalIntWithLimit((env)->txBuffer.data, &(env)->txBuffer.len, INT,DIGITS) | ||||
| 
 | ||||
| void AtCmdTxSendLn(tAtCmd *env); | ||||
| 
 | ||||
| 
 | ||||
| //rx methods
 | ||||
| #define AtCmdRxClear(env) vAsciiStringClean((env)->rxBuffer.data, &(env)->rxBuffer.len) | ||||
| 
 | ||||
| #define AtCmdRxReadRAW(ENV, BUF, LEN, TIMEOUT)  SerialPortReceive((env)->io,  BUF, LEN, TIMEOUT) | ||||
| 
 | ||||
| bool AtBufferBeginWith(tAtBuffer *env, char *str, size_t strLen); | ||||
| 
 | ||||
| #define AtBufferBeginWithStatic(ENV, STR)   AtBufferBeginWith(ENV,STR,sizeof(STR)) | ||||
| 
 | ||||
| bool AtCmdRxBeginWith(tAtCmd *env, char *str, size_t strLen); | ||||
| 
 | ||||
| #define AtCmdRxBeginWithStatic(ENV, STR)   AtCmdRxBeginWith(ENV,STR,sizeof(STR)) | ||||
| 
 | ||||
| 
 | ||||
| //complex rx methods
 | ||||
| AtCommandResult AtCmdReceiveNextLine(tAtCmd *env, uint16_t timeout); | ||||
| 
 | ||||
| AtCommandResult AtCmdOkErrAnswer(tAtCmd *env, uint16_t timeout); | ||||
| 
 | ||||
| AtCommandResult AtCmdReceiveNextChar(tAtCmd *env, uint16_t timeout); | ||||
| 
 | ||||
| AtCommandResult AtCmdReceiveChar(tAtCmd *env, uint16_t timeout); | ||||
| 
 | ||||
| AtCommandResult AtGsmTelitLe910_SIMCardDetect(tAtCmd *env); | ||||
| 
 | ||||
| extern const char AT_ESC_STR[2]; | ||||
| 
 | ||||
| //if not ok return - если не все хорошо возвращаем результат от FUNC
 | ||||
| #define AT_INOKR(FUNC) { AtCommandResult result = FUNC; if(result != AT_OK) return result; } | ||||
| 
 | ||||
| 
 | ||||
| #endif //GSMCOMMONAT_GSMCOMMONATPRIVATE_H
 | ||||
|  | @ -0,0 +1,51 @@ | |||
| //
 | ||||
| // Created by xemon on 07.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #include "AtCmdCommonProtected.h" | ||||
| #include "SystemDelayInterface.h" | ||||
| 
 | ||||
| 
 | ||||
| void AtCmdInit( | ||||
|         tAtCmd *env, | ||||
|         tSerialPortIO *io, | ||||
|         uint8_t *txBuffer, | ||||
|         size_t txBufferSize, | ||||
|         uint8_t *rxBuffer, | ||||
|         size_t rxBufferSize, | ||||
|         uint32_t stdTxTimeout, | ||||
|         uint32_t stdRxTimeout | ||||
| ) { | ||||
|     env->io = io; | ||||
|     env->rxBuffer.data = (char *) rxBuffer; | ||||
|     env->rxBuffer.limit = rxBufferSize; | ||||
| 
 | ||||
|     env->txBuffer.data = (char *) txBuffer; | ||||
|     env->txBuffer.limit = txBufferSize; | ||||
| 
 | ||||
|     vAsciiStringInit(env->txBuffer.data, &env->txBuffer.len, env->txBuffer.limit); | ||||
|     vAsciiStringInit(env->rxBuffer.data, &env->rxBuffer.len, env->rxBuffer.limit); | ||||
| 
 | ||||
|     env->stdRxTimeout = stdRxTimeout; | ||||
|     env->stdTxTimeout = stdTxTimeout; | ||||
|     env->urcProcessor.process = NULL; | ||||
| } | ||||
| 
 | ||||
| AtCommandResult AtCmd(tAtCmd *env) { | ||||
|     AtCmdPrepare(env); | ||||
|     AtCmdSendStatic(env, "AT\r\n"); | ||||
|     return AtCmdOkErrAnswer(env, env->stdRxTimeout); | ||||
| } | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitOk(tAtCmd *env, uint32_t retryInterval, uint32_t timeout) { | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
|     while (endMs > SystemGetMs()) { | ||||
|         if (AtCmd(env) == AT_OK) { | ||||
|             return AT_OK; | ||||
|         } else { | ||||
|             SystemDelayMs(retryInterval); | ||||
|         } | ||||
|     } | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
|  | @ -0,0 +1,32 @@ | |||
| //
 | ||||
| // Created by xemon on 28.11.22.
 | ||||
| //
 | ||||
| #include "AtCmdCommonProtected.h" | ||||
| 
 | ||||
| const char AT_ESC_STR[2] = {0x1A, 0x00}; | ||||
| 
 | ||||
| 
 | ||||
| void AtCmdProcessUnresolvedLine(tAtCmd *env) { | ||||
|     if (env->urcProcessor.process) { | ||||
|         AtCmdUrcProcessor_Process(&env->urcProcessor, &env->rxBuffer); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void AtCmdProcessUnresolvedLines(tAtCmd *env) { | ||||
|     while (AtCmdReceiveNextLine(env, 1) == AT_OK) { | ||||
|         AtCmdProcessUnresolvedLine(env); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void AtCmdSetUrcProcessor(tAtCmd *env, void *urcProcEnv, void *urcProcFunc) { | ||||
|     env->urcProcessor.env = urcProcEnv; | ||||
|     env->urcProcessor.process = urcProcFunc; | ||||
| } | ||||
| 
 | ||||
| void AtCmdClearUrcProcessor(tAtCmd *env) { | ||||
|     env->urcProcessor.process = NULL; | ||||
| } | ||||
| 
 | ||||
| void AtCmdPrepare(tAtCmd *env) { | ||||
|     AtCmdProcessUnresolvedLines(env); | ||||
| } | ||||
|  | @ -0,0 +1,111 @@ | |||
| //
 | ||||
| // Created by xemon on 07.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #include <stdbool.h> | ||||
| #include <memory.h> | ||||
| #include "AtCmdCommonProtected.h" | ||||
| #include "SystemDelayInterface.h" | ||||
| 
 | ||||
| AtCommandResult AtCmdReceiveNextChar(tAtCmd *env, uint16_t timeout) { | ||||
|     uint8_t received = SerialPortReceive( | ||||
|             env->io, (uint8_t *) env->rxBuffer.data + env->rxBuffer.len, 1, timeout | ||||
|     ); | ||||
| 
 | ||||
|     if (received) { | ||||
|         ++env->rxBuffer.len; | ||||
|         return AT_OK; | ||||
|     } | ||||
| 
 | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
| AtCommandResult AtCmdReceiveChar(tAtCmd *env, uint16_t timeout) { | ||||
|     AtCmdRxClear(env); | ||||
|     return AtCmdReceiveNextChar(env, timeout); | ||||
| } | ||||
| 
 | ||||
| AtCommandResult AtCmdReceiveNextLine(tAtCmd *env, uint16_t timeout) { | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while (endMs > SystemGetMs()) { | ||||
|         AtCmdRxClear(env); | ||||
|         env->rxBuffer.len = SerialPortReceiveTo( | ||||
|                 env->io, (uint8_t *) env->rxBuffer.data, env->rxBuffer.limit, '\n', timeout | ||||
|         ); | ||||
| 
 | ||||
|         if (env->rxBuffer.len == 0) { | ||||
|             return AT_TIMEOUT; | ||||
|         } | ||||
| 
 | ||||
|         if (env->rxBuffer.data[0] == '\n') { | ||||
|             continue; | ||||
|         } | ||||
| 
 | ||||
|         if (env->rxBuffer.data[env->rxBuffer.len - 1] != '\n') { | ||||
|             return AT_ERROR; | ||||
|         } | ||||
| 
 | ||||
|         return AT_OK; | ||||
|     } | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
| bool AtBufferBeginWith(tAtBuffer *env, char *str, size_t strLen) { | ||||
|     if (strLen > env->len) return AT_ERROR; | ||||
|     return strnstr(env->data, str, strLen); | ||||
| } | ||||
| 
 | ||||
| bool AtCmdRxBeginWith(tAtCmd *env, char *str, size_t strLen) { | ||||
|     return AtBufferBeginWith(&env->rxBuffer, str, strLen); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| AtCommandResult AtCmdOkErrAnswer(tAtCmd *env, uint16_t timeout) { | ||||
|     uint32_t leftMs; | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while (endMs > SystemGetMs()) { | ||||
|         leftMs = endMs - SystemGetMs(); | ||||
|         if (AtCmdReceiveNextLine(env, leftMs) == AT_OK) { | ||||
|             if (AtCmdRxBeginWithStatic(env, "OK"))return AT_OK; | ||||
|             if (AtCmdRxBeginWithStatic(env, "ERROR"))return AT_ERROR; | ||||
|             AtCmdProcessUnresolvedLine(env); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitPrefix(tAtCmd *env, uint16_t timeout, char *line, size_t lineLen) { | ||||
|     uint32_t leftMs; | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while (endMs > SystemGetMs()) { | ||||
|         leftMs = endMs - SystemGetMs(); | ||||
|         if (AtCmdReceiveNextLine(env, leftMs) == AT_OK) { | ||||
|             if (AtCmdRxBeginWith(env, line, lineLen)) { | ||||
|                 return AT_OK; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
| AtCommandResult AtCmdWaitChar(tAtCmd *env, uint16_t timeout, char line) { | ||||
| 
 | ||||
|     uint32_t end = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while (SystemGetMs() < end) { | ||||
|         if (AtCmdReceiveChar(env, end - SystemGetMs()) == AT_OK) { | ||||
|             if (*env->rxBuffer.data == line) { | ||||
|                 return AT_OK; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return AT_TIMEOUT; | ||||
| } | ||||
| 
 | ||||
|  | @ -0,0 +1,11 @@ | |||
| //
 | ||||
| // Created by xemon on 07.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #include "AtCmdCommonProtected.h" | ||||
| #include "SystemDelayInterface.h" | ||||
| 
 | ||||
| void AtCmdTxSendLn(tAtCmd *env) { | ||||
|     AtCmdTxAddStatic(env, "\r\n"); | ||||
|     AtCmdSend(env, env->txBuffer.data, env->txBuffer.len); | ||||
| } | ||||
|  | @ -0,0 +1,29 @@ | |||
| { | ||||
|   "dep": [ | ||||
|     { | ||||
|       "type": "git", | ||||
|       "provider": "GONEC_BOOT_MODEM", | ||||
|       "repo": "SerialPort" | ||||
|     }, | ||||
|     { | ||||
|       "type": "git", | ||||
|       "provider": "GONEC_BOOT_MODEM", | ||||
|       "repo": "AsciiStringAssemblingUtils" | ||||
|     }, | ||||
|     { | ||||
|       "type": "git", | ||||
|       "provider": "GONEC_BOOT_MODEM", | ||||
|       "repo": "AsciiStringParsingUtils" | ||||
|     } | ||||
|   ], | ||||
|   "cmake": { | ||||
|     "inc_dirs": [ | ||||
|       "Inc", | ||||
|       "AtCommandsInc" | ||||
|     ], | ||||
|     "srcs": [ | ||||
|       "Src/**.c", | ||||
|       "AtCommandsSrc/**.c" | ||||
|     ] | ||||
|   } | ||||
| } | ||||
		Loading…
	
		Reference in New Issue