2021-11-25 12:45:44 +01:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2013 Armink
|
2018-10-19 15:51:27 +02:00
|
|
|
*
|
2021-11-25 12:45:44 +01:00
|
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
2018-10-19 15:51:27 +02:00
|
|
|
*
|
2021-11-25 12:45:44 +01:00
|
|
|
* SPDX-FileContributor: 2016-2021 Espressif Systems (Shanghai) CO LTD
|
2018-10-19 15:51:27 +02:00
|
|
|
*/
|
|
|
|
/*
|
2021-11-25 12:45:44 +01:00
|
|
|
* FreeModbus Libary: ESP32 Port
|
|
|
|
* Copyright (C) 2013 Armink <armink.ztl@gmail.com>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* IF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* File: $Id: port.c,v 1.60 2015/02/01 9:18:05 Armink $
|
|
|
|
*/
|
2018-10-19 15:51:27 +02:00
|
|
|
|
|
|
|
/* ----------------------- System includes --------------------------------*/
|
|
|
|
|
|
|
|
/* ----------------------- Modbus includes ----------------------------------*/
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "sys/lock.h"
|
|
|
|
#include "port.h"
|
|
|
|
|
|
|
|
/* ----------------------- Variables ----------------------------------------*/
|
|
|
|
static _lock_t s_port_lock;
|
2020-07-22 00:34:04 +08:00
|
|
|
static UCHAR ucPortMode = 0;
|
2018-10-19 15:51:27 +02:00
|
|
|
|
|
|
|
/* ----------------------- Start implementation -----------------------------*/
|
|
|
|
inline void
|
2019-07-16 16:33:30 +07:00
|
|
|
vMBPortEnterCritical(void)
|
2018-10-19 15:51:27 +02:00
|
|
|
{
|
|
|
|
_lock_acquire(&s_port_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
2019-07-16 16:33:30 +07:00
|
|
|
vMBPortExitCritical(void)
|
2018-10-19 15:51:27 +02:00
|
|
|
{
|
|
|
|
_lock_release(&s_port_lock);
|
|
|
|
}
|
2020-07-22 00:34:04 +08:00
|
|
|
|
|
|
|
UCHAR
|
|
|
|
ucMBPortGetMode( void )
|
|
|
|
{
|
|
|
|
return ucPortMode;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
vMBPortSetMode( UCHAR ucMode )
|
|
|
|
{
|
|
|
|
ENTER_CRITICAL_SECTION();
|
|
|
|
ucPortMode = ucMode;
|
|
|
|
EXIT_CRITICAL_SECTION();
|
|
|
|
}
|
|
|
|
|
|
|
|
#if MB_TCP_DEBUG
|
|
|
|
|
|
|
|
// This function is kept to realize legacy freemodbus frame logging functionality
|
|
|
|
void
|
|
|
|
prvvMBTCPLogFrame( const CHAR * pucMsg, UCHAR * pucFrame, USHORT usFrameLen )
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
int res = 0;
|
|
|
|
int iBufPos = 0;
|
|
|
|
size_t iBufLeft = MB_TCP_FRAME_LOG_BUFSIZE;
|
|
|
|
static CHAR arcBuffer[MB_TCP_FRAME_LOG_BUFSIZE];
|
|
|
|
|
|
|
|
assert( pucFrame != NULL );
|
|
|
|
|
|
|
|
for ( i = 0; i < usFrameLen; i++ ) {
|
|
|
|
// Print some additional frame information.
|
|
|
|
switch ( i )
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
// TID = Transaction Identifier.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, "| TID = " );
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
// PID = Protocol Identifier.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " | PID = " );
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
// Length
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " | LEN = " );
|
|
|
|
break;
|
|
|
|
case 6:
|
|
|
|
// UID = Unit Identifier.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " | UID = " );
|
|
|
|
break;
|
|
|
|
case 7:
|
|
|
|
// MB Function Code.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " | FUNC = " );
|
|
|
|
break;
|
|
|
|
case 8:
|
|
|
|
// MB PDU rest.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " | DATA = " );
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
res = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if( res == -1 ) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
iBufPos += res;
|
|
|
|
iBufLeft -= res;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Print the data.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, "%02X", pucFrame[i] );
|
|
|
|
if( res == -1 ) {
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
iBufPos += res;
|
|
|
|
iBufLeft -= res;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( res != -1 ) {
|
|
|
|
// Append an end of frame string.
|
|
|
|
res = snprintf( &arcBuffer[iBufPos], iBufLeft, " |" );
|
|
|
|
if( res != -1 ) {
|
|
|
|
ESP_LOGD(pucMsg, "%s", arcBuffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|