Merge branch 'master' of gitea.larke.org:klarke/libcw

This commit is contained in:
kevin.larke 2020-04-04 17:28:01 -04:00
commit 0b2f8091d0
6 changed files with 87 additions and 76 deletions

View File

@ -1,49 +1,47 @@
dir = src/libcw
libcwHDR = libcwHDR =
libcwSRC = libcwSRC =
libcwHDR += $(dir)/cwCommon.h $(dir)/cwCommonImpl.h $(dir)/cwMem.h $(dir)/cwLog.h $(dir)/cwUtility.h libcwHDR += src/libcw/cwCommon.h src/libcw/cwCommonImpl.h src/libcw/cwMem.h src/libcw/cwLog.h src/libcw/cwUtility.h
libcwSRC += $(dir)/cwCommonImpl.cpp $(dir)/cwMem.cpp $(dir)/cwLog.cpp $(dir)/cwUtility.cpp libcwSRC += src/libcw/cwCommonImpl.cpp src/libcw/cwMem.cpp src/libcw/cwLog.cpp src/libcw/cwUtility.cpp
libcwHDR += $(dir)/cwFileSys.h $(dir)/cwText.h $(dir)/cwFile.h $(dir)/cwTime.h $(dir)/cwLex.h $(dir)/cwNumericConvert.h libcwHDR += src/libcw/cwFileSys.h src/libcw/cwText.h src/libcw/cwFile.h src/libcw/cwTime.h src/libcw/cwLex.h src/libcw/cwNumericConvert.h
libcwSRC += $(dir)/cwFileSys.cpp $(dir)/cwText.cpp $(dir)/cwFile.cpp $(dir)/cwTime.cpp $(dir)/cwLex.cpp libcwSRC += src/libcw/cwFileSys.cpp src/libcw/cwText.cpp src/libcw/cwFile.cpp src/libcw/cwTime.cpp src/libcw/cwLex.cpp
libcwHDR += $(dir)/cwObject.h $(dir)/cwObjectTemplate.h $(dir)/cwTextBuf.h libcwHDR += src/libcw/cwObject.h src/libcw/cwObjectTemplate.h src/libcw/cwTextBuf.h
libcwSRC += $(dir)/cwObject.cpp $(dir)/cwTextBuf.cpp libcwSRC += src/libcw/cwObject.cpp src/libcw/cwTextBuf.cpp
libcwHDR += $(dir)/cwThread.h $(dir)/cwMutex.h $(dir)/cwMpScNbQueue.h libcwHDR += src/libcw/cwThread.h src/libcw/cwMutex.h src/libcw/cwMpScNbQueue.h
libcwSRC += $(dir)/cwThread.cpp $(dir)/cwMutex.cpp libcwSRC += src/libcw/cwThread.cpp src/libcw/cwMutex.cpp
libcwHDR += $(dir)/cwWebSock.h $(dir)/cwWebSockSvr.h $(dir)/cwLib.h libcwHDR += src/libcw/cwWebSock.h src/libcw/cwWebSockSvr.h src/libcw/cwLib.h
libcwSRC += $(dir)/cwWebSock.cpp $(dir)/cwWebSockSvr.cpp $(dir)/cwLib.cpp libcwSRC += src/libcw/cwWebSock.cpp src/libcw/cwWebSockSvr.cpp src/libcw/cwLib.cpp
libcwHDR += $(dir)/cwUiDecls.h $(dir)/cwUi.h $(dir)/cwUiTest.h libcwHDR += src/libcw/cwUiDecls.h src/libcw/cwUi.h src/libcw/cwUiTest.h
libcwSRC += $(dir)/cwUi.cpp $(dir)/cwUiTest.cpp libcwSRC += src/libcw/cwUi.cpp src/libcw/cwUiTest.cpp
libcwHDR += $(dir)/cwSerialPortDecls.h $(dir)/cwSerialPort.h $(dir)/cwSerialPortSrv.h libcwHDR += src/libcw/cwSerialPortDecls.h src/libcw/cwSerialPort.h src/libcw/cwSerialPortSrv.h
libcwSRC += $(dir)/cwSerialPort.cpp $(dir)/cwSerialPortSrv.cpp libcwSRC += src/libcw/cwSerialPort.cpp src/libcw/cwSerialPortSrv.cpp
libcwHDR += $(dir)/cwMidiDecls.h $(dir)/cwMidi.h $(dir)/cwMidiPort.h libcwHDR += src/libcw/cwMidiDecls.h src/libcw/cwMidi.h src/libcw/cwMidiPort.h
libcwSRC += $(dir)/cwMidi.cpp $(dir)/cwMidiPort.cpp $(dir)/cwMidiAlsa.cpp libcwSRC += src/libcw/cwMidi.cpp src/libcw/cwMidiPort.cpp src/libcw/cwMidiAlsa.cpp
libcwHDR += $(dir)/cwAudioDeviceDecls.h $(dir)/cwAudioDevice.h $(dir)/cwAudioDeviceAlsa.h libcwHDR += src/libcw/cwAudioDeviceDecls.h src/libcw/cwAudioDevice.h src/libcw/cwAudioDeviceAlsa.h
libcwSRC += $(dir)/cwAudioDevice.cpp $(dir)/cwAudioDeviceAlsa.cpp $(dir)/cwAudioDeviceTest.cpp libcwSRC += src/libcw/cwAudioDevice.cpp src/libcw/cwAudioDeviceAlsa.cpp src/libcw/cwAudioDeviceTest.cpp
libcwHDR += $(dir)/cwAudioBufDecls.h $(dir)/cwAudioBuf.h libcwHDR += src/libcw/cwAudioBufDecls.h src/libcw/cwAudioBuf.h
libcwSRC += $(dir)/cwAudioBuf.cpp libcwSRC += src/libcw/cwAudioBuf.cpp
libcwHDR += $(dir)/cwSocketDecls.h $(dir)/cwSocket.h libcwHDR += src/libcw/cwSocketDecls.h src/libcw/cwSocket.h
libcwSRC += $(dir)/cwSocket.cpp libcwSRC += src/libcw/cwSocket.cpp
libcwHDR += $(dir)/cwIo.h $(dir)/cwIoTest.h libcwHDR += src/libcw/cwIo.h src/libcw/cwIoTest.h
libcwSRC += $(dir)/cwIo.cpp $(dir)/cwIoTest.cpp libcwSRC += src/libcw/cwIo.cpp src/libcw/cwIoTest.cpp
libcwHDR += $(dir)/cwTcpSocket.h $(dir)/cwTcpSocketSrv.h $(dir)/cwTcpSocketTest.h libcwHDR += src/libcw/cwTcpSocket.h src/libcw/cwTcpSocketSrv.h src/libcw/cwTcpSocketTest.h
libcwSRC += $(dir)/cwTcpSocket.cpp $(dir)/cwTcpSocketSrv.cpp $(dir)/cwTcpSocketTest.cpp libcwSRC += src/libcw/cwTcpSocket.cpp src/libcw/cwTcpSocketSrv.cpp src/libcw/cwTcpSocketTest.cpp
libcwHDR += $(dir)/cwMdns.h $(dir)/cwEuCon.h $(dir)/cwDnsSd.h $(dir)/dns_sd/dns_sd.h $(dir)/dns_sd/dns_sd_print.h $(dir)/dns_sd/dns_sd_const.h $(dir)/dns_sd/fader.h $(dir)/dns_sd/rpt.h libcwHDR += src/libcw/cwMdns.h src/libcw/cwEuCon.h src/libcw/cwDnsSd.h src/libcw/dns_sd/dns_sd.h src/libcw/dns_sd/dns_sd_print.h src/libcw/dns_sd/dns_sd_const.h src/libcw/dns_sd/fader.h src/libcw/dns_sd/rpt.h
libcwSRC += $(dir)/cwMdns.cpp $(dir)/cwEuCon.cpp $(dir)/cwDnsSd.cpp $(dir)/dns_sd/dns_sd.cpp $(dir)/dns_sd/dns_sd_print.cpp $(dir)/dns_sd/fader.cpp $(dir)/dns_sd/rpt.cpp libcwSRC += src/libcw/cwMdns.cpp src/libcw/cwEuCon.cpp src/libcw/cwDnsSd.cpp src/libcw/dns_sd/dns_sd.cpp src/libcw/dns_sd/dns_sd_print.cpp src/libcw/dns_sd/fader.cpp src/libcw/dns_sd/rpt.cpp

View File

@ -166,7 +166,7 @@ namespace cw
case SND_PCM_STATE_PAUSED: return "paused"; case SND_PCM_STATE_PAUSED: return "paused";
case SND_PCM_STATE_SUSPENDED: return "suspended"; case SND_PCM_STATE_SUSPENDED: return "suspended";
case SND_PCM_STATE_DISCONNECTED: return "disconnected"; case SND_PCM_STATE_DISCONNECTED: return "disconnected";
case SND_PCM_STATE_PRIVATE1: return "private1"; //case SND_PCM_STATE_PRIVATE1: return "private1";
} }
return "<invalid>"; return "<invalid>";
@ -491,7 +491,7 @@ namespace cw
case SND_PCM_STATE_DRAINING: case SND_PCM_STATE_DRAINING:
case SND_PCM_STATE_PAUSED: case SND_PCM_STATE_PAUSED:
case SND_PCM_STATE_DISCONNECTED: case SND_PCM_STATE_DISCONNECTED:
case SND_PCM_STATE_PRIVATE1: //case SND_PCM_STATE_PRIVATE1:
//case SND_PCM_STATE_LAST: //case SND_PCM_STATE_LAST:
break; break;
} }
@ -872,7 +872,7 @@ namespace cw
case SND_PCM_STATE_DRAINING: case SND_PCM_STATE_DRAINING:
case SND_PCM_STATE_PAUSED: case SND_PCM_STATE_PAUSED:
case SND_PCM_STATE_DISCONNECTED: case SND_PCM_STATE_DISCONNECTED:
case SND_PCM_STATE_PRIVATE1: //case SND_PCM_STATE_PRIVATE1:
continue; continue;
case SND_PCM_STATE_RUNNING: case SND_PCM_STATE_RUNNING:

View File

@ -328,10 +328,11 @@ namespace cw
typedef struct eucon_str typedef struct eucon_str
{ {
sock::handle_t sockMgrH; sock::handle_t sockMgrH; // socket mgr handle
fbank_t* fbankL; fbank_t* fbankL; // List of fader banks
unsigned maxFaderBankN; unsigned maxFaderBankN; // maximum number of fader banks
unsigned sockTimeOutMs; unsigned sockTimeOutMs; // socket time out
unsigned faderTcpPort; // Fader TCP port TODO: we shouuld be getting this from the MDNS SRV record
} eucon_t; } eucon_t;
@ -353,10 +354,18 @@ namespace cw
rc_t rc0; rc_t rc0;
fbank_t* fb = p->fbankL; fbank_t* fb = p->fbankL;
for(; fb!=nullptr; fb=fb->link) while( fb!=nullptr )
{
fbank_t* fb0 = fb->link;
if((rc0 = _destroyFBank(p,fb)) != kOkRC ) if((rc0 = _destroyFBank(p,fb)) != kOkRC )
rc = rc0;; rc = rc0;;
mem::release(fb);
fb = fb0;
}
if( p->sockMgrH.isValid() ) if( p->sockMgrH.isValid() )
if((rc = sock::destroyMgr(p->sockMgrH)) != kOkRC ) if((rc = sock::destroyMgr(p->sockMgrH)) != kOkRC )
return rc; return rc;
@ -460,6 +469,7 @@ namespace cw
return; return;
} }
//
if( data!=nullptr && dataByteCnt >= 4 ) if( data!=nullptr && dataByteCnt >= 4 )
{ {
//printHex(data,dataByteCnt); //printHex(data,dataByteCnt);
@ -473,7 +483,7 @@ namespace cw
{ {
fb->protoState = kWaitForHandshake_2_Id; fb->protoState = kWaitForHandshake_2_Id;
_sendHandshake_1( fb ); _sendHandshake_1( fb );
printf("Rcvd (0x0b) HS 1 - sent 0x0c\n"); printf("%i : Rcvd (0x0b) HS 1 - sent 0x0c\n", fb->fbIndex);
} }
break; break;
@ -481,7 +491,7 @@ namespace cw
if( hdr == 0x0d ) if( hdr == 0x0d )
{ {
fb->protoState = kResponse_3_A_Id; fb->protoState = kResponse_3_A_Id;
printf("Rcvd (0x0d) HS 2 - Sending setup data\n"); printf("%i : Rcvd (0x0d) HS 2 - Sending setup data\n",fb->fbIndex);
} }
break; break;
@ -511,7 +521,7 @@ namespace cw
break; break;
case kRunning_Id: case kRunning_Id:
printf("Rcv: %i : ",dataByteCnt ); printf("%i : Rcv: %i : ",fb->fbIndex, dataByteCnt );
for(unsigned i=0; i<dataByteCnt; ++i) for(unsigned i=0; i<dataByteCnt; ++i)
printf("0x%02x ",((uint8_t*)data)[i]); printf("0x%02x ",((uint8_t*)data)[i]);
printf("\n"); printf("\n");
@ -529,14 +539,12 @@ namespace cw
} }
} }
rc_t _on_McMix_DNS_SD_TXT( eucon_t* p, const char* numberText, unsigned numberTextCharN, const struct sockaddr_in* fromAddr )
rc_t _on_McMix_DNS_SD_SRV( eucon_t* p, const char* numberText, unsigned numberTextCharN, const struct sockaddr_in* fromAddr )
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
unsigned tcpFlags = sock::kTcpFl | sock::kBlockingFl | sock::kStreamFl | sock::kReuseAddrFl | sock::kReusePortFl; unsigned tcpFlags = sock::kTcpFl | sock::kBlockingFl | sock::kStreamFl | sock::kReuseAddrFl | sock::kReusePortFl;
fbank_t* fb = nullptr; fbank_t* fb = nullptr;
unsigned fbIndex = 0; unsigned fbIndex = 0;
sock::portNumber_t fbPort = fromAddr->sin_port;
char fbIP[ INET_ADDRSTRLEN+1 ]; char fbIP[ INET_ADDRSTRLEN+1 ];
// copy the "MC Mix" suffix number into a zero terminated string // copy the "MC Mix" suffix number into a zero terminated string
@ -550,7 +558,7 @@ namespace cw
// validate the value // validate the value
if( !(0 < fbIndex && fbIndex <= p->maxFaderBankN ) ) if( !(0 < fbIndex && fbIndex <= p->maxFaderBankN ) )
return cwLogError(kInvalidArgRC,"The fader bank index %i is not valid.", fbIndex ); return cwLogError(kInvalidArgRC,"The fader bank number %i is not valid.", fbIndex );
// convert fbIndex to a zero based index // convert fbIndex to a zero based index
fbIndex -= 1; fbIndex -= 1;
@ -563,12 +571,14 @@ namespace cw
return cwLogError(kOpFailRC,"The fader bank index %i failed.", fbIndex ); return cwLogError(kOpFailRC,"The fader bank index %i failed.", fbIndex );
} }
if( fb->protoState == kSendHandshake_0_Id )
{
// convert the fromAddr to a string // convert the fromAddr to a string
if((rc = sock::addrToString( fromAddr, fbIP, INET_ADDRSTRLEN)) != kOkRC ) if((rc = sock::addrToString( fromAddr, fbIP, INET_ADDRSTRLEN)) != kOkRC )
return cwLogError(rc,"IP address to string conversion failed.", fbIndex); return cwLogError(rc,"IP address to string conversion failed.", fbIndex);
// create the TCP socket // create the TCP socket
if((rc = sock::create( p->sockMgrH, fb->sockUserId, sock::kInvalidPortNumber, tcpFlags, p->sockTimeOutMs, _tcpCallback, p, fbIP, fbPort )) != kOkRC ) if((rc = sock::create( p->sockMgrH, fb->sockUserId, sock::kInvalidPortNumber, tcpFlags, p->sockTimeOutMs, _tcpCallback, p, fbIP, p->faderTcpPort )) != kOkRC )
return cwLogError(rc,"The TCP socket for fader bank index %i failed. ", fbIndex); return cwLogError(rc,"The TCP socket for fader bank index %i failed. ", fbIndex);
fb->remoteAddr = fromAddr->sin_addr.s_addr; fb->remoteAddr = fromAddr->sin_addr.s_addr;
@ -577,6 +587,7 @@ namespace cw
_sendHandshake_0( fb ); _sendHandshake_0( fb );
fb->protoState = kWaitForHandshake_1_Id; fb->protoState = kWaitForHandshake_1_Id;
}
return rc; return rc;
} }
@ -595,15 +606,14 @@ namespace cw
const char* name = (const char*)(u+6); const char* name = (const char*)(u+6);
const char* label = "MC Mix - "; const char* label = "MC Mix - ";
printf("%.*s|%li\n", name[0], name+1, strlen(label) ); printf("%.*s|%i\n", name[0], name+1, strlen(label) );
// if this a 'MC Mix' DNS-SD SRV reply // if this a 'MC Mix' DNS-SD SRV reply
if( strncmp(label, name+1, strlen(label)) == 0 ) if( strncmp(label, name+1, strlen(label)) == 0 )
{ {
unsigned n = strlen(label);
unsigned n = strlen(label) + 1; if((rc = _on_McMix_DNS_SD_TXT( p, name+n+1, name[0]-n, fromAddr )) != kOkRC )
if((rc = _on_McMix_DNS_SD_SRV( p, name+n, name[0]-n, fromAddr )) != kOkRC )
cwLogError(rc,"%.*s initialization failed.",name[0],name+1); cwLogError(rc,"%.*s initialization failed.",name[0],name+1);
} }
@ -655,6 +665,7 @@ cw::rc_t cw::net::eucon::create( handle_t& hRef, const args_t& args )
p->maxFaderBankN = args.maxFaderBankN; p->maxFaderBankN = args.maxFaderBankN;
p->sockTimeOutMs = args.sockTimeOutMs; p->sockTimeOutMs = args.sockTimeOutMs;
p->faderTcpPort = args.faderTcpPort;
hRef.set(p); hRef.set(p);
errLabel: errLabel:
@ -710,6 +721,7 @@ bool quitFl = false;
void sighandler(int sig) void sighandler(int sig)
{ {
printf("Signal caught!\n");
quitFl = true; quitFl = true;
} }
@ -724,14 +736,15 @@ cw::rc_t cw::net::eucon::test()
args.mdnsPort = 5353; args.mdnsPort = 5353;
args.sockTimeOutMs = 50; args.sockTimeOutMs = 50;
args.maxFaderBankN = 8; args.maxFaderBankN = 8;
args.faderTcpPort = 49168;
args.maxSockN = 50; args.maxSockN = 50;
cw::log::createGlobal();
// create the EuCon controller // Create the EuCon controller
if((rc = create( h, args )) != kOkRC ) if((rc = create( h, args )) != kOkRC )
return cwLogError(rc,"Unable to create EuCon server."); return cwLogError(rc,"Unable to create EuCon server.");
cwLogInfo("EuCon controller waiting ...");
while( !quitFl ) while( !quitFl )
{ {
exec(h,args.sockTimeOutMs); exec(h,args.sockTimeOutMs);

View File

@ -18,13 +18,13 @@ namespace cw
typedef struct args_str typedef struct args_str
{ {
unsigned recvBufByteN; unsigned recvBufByteN; // Socket receive buffer size
const char* mdnsIP; const char* mdnsIP; // MDNS IP (always: "224.0.0.251")
sock::portNumber_t mdnsPort; sock::portNumber_t mdnsPort; // MDNS port (always 5353)
unsigned sockTimeOutMs; unsigned sockTimeOutMs; // socket poll time out in milliseconds (also determines the cwEuCon update rate)
sock::portNumber_t tcpPort; sock::portNumber_t faderTcpPort; // Fader TCP port (e.g. 49168)
unsigned maxSockN; unsigned maxSockN; // maximum number of socket to allow in the socket manager
unsigned maxFaderBankN; unsigned maxFaderBankN; // maximum number of fader banks to support
} args_t; } args_t;
rc_t create( handle_t& hRef, const args_t& a ); rc_t create( handle_t& hRef, const args_t& a );

View File

@ -124,8 +124,8 @@ namespace cw
void _objTypePrintUInt16( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.u16); } void _objTypePrintUInt16( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.u16); }
void _objTypePrintInt32( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.i32); } void _objTypePrintInt32( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.i32); }
void _objTypePrintUInt32( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.u32); } void _objTypePrintUInt32( const object_t* o, print_ctx_t& c ) { printf("%i",o->u.u32); }
void _objTypePrintInt64( const object_t* o, print_ctx_t& c ) { printf("%li",o->u.i64); } void _objTypePrintInt64( const object_t* o, print_ctx_t& c ) { printf("%lli",o->u.i64); }
void _objTypePrintUInt64( const object_t* o, print_ctx_t& c ) { printf("%li",o->u.u64); } void _objTypePrintUInt64( const object_t* o, print_ctx_t& c ) { printf("%lli",o->u.u64); }
void _objTypePrintBool( const object_t* o, print_ctx_t& c ) { printf("%s",o->u.b ? "true" : "false"); } void _objTypePrintBool( const object_t* o, print_ctx_t& c ) { printf("%s",o->u.b ? "true" : "false"); }
void _objTypePrintFloat( const object_t* o, print_ctx_t& c ) { printf("%f",o->u.f); } void _objTypePrintFloat( const object_t* o, print_ctx_t& c ) { printf("%f",o->u.f); }
void _objTypePrintDouble( const object_t* o, print_ctx_t& c ) { printf("%f",o->u.d); } void _objTypePrintDouble( const object_t* o, print_ctx_t& c ) { printf("%f",o->u.d); }

View File

@ -285,7 +285,7 @@ namespace cw
{ {
rc_t rc = kOkRC; rc_t rc = kOkRC;
const object_t* oo; const object_t* oo;
ele_t* parent_ele; //ele_t* parent_ele;
const char* jsId; const char* jsId;
// find the parent pair // find the parent pair
@ -304,7 +304,7 @@ namespace cw
//} //}
return rc;
} }