Put relay-only fields into a struct for easier identification. No code change.

This commit is contained in:
ehouse 2006-10-02 14:26:56 +00:00
parent 9837d8cca7
commit 715d01b8a4

View file

@ -55,7 +55,9 @@ typedef struct AddressRecord {
MsgID nextMsgID; /* on a per-channel basis */ MsgID nextMsgID; /* on a per-channel basis */
MsgID lastMsgReceived; /* on a per-channel basis */ MsgID lastMsgReceived; /* on a per-channel basis */
XP_PlayerAddr channelNo; XP_PlayerAddr channelNo;
XWHostID hostID; /* used for relay case */ struct {
XWHostID hostID; /* used for relay case */
} r;
} AddressRecord; } AddressRecord;
#define ADDRESSRECORD_SIZE_68K 20 #define ADDRESSRECORD_SIZE_68K 20
@ -88,24 +90,26 @@ struct CommsCtxt {
CommsAddrRec addr; CommsAddrRec addr;
/* Stuff for relays */ /* Stuff for relays */
XWHostID myHostID; /* 0 if unset, 1 if acting as server, random for struct {
client */ XWHostID myHostID; /* 0 if unset, 1 if acting as server,
CommsRelaystate relayState; /* not saved: starts at UNCONNECTED */ random for client */
CookieID cookieID; /* not saved; temp standin for cookie; set by CommsRelaystate relayState; /* not saved: starts at UNCONNECTED */
relay */ CookieID cookieID; /* not saved; temp standin for cookie; set
/* permanent globally unique name, set by relay and forever after by relay */
associated with this game. Used to reconnect. */ /* permanent globally unique name, set by relay and forever after
XP_UCHAR connName[MAX_CONNNAME_LEN+1]; associated with this game. Used to reconnect. */
XP_UCHAR connName[MAX_CONNNAME_LEN+1];
/* heartbeat: for periodic pings if relay thinks the network the device is /* heartbeat: for periodic pings if relay thinks the network the
on requires them. Not saved since only valid when connected, and we device is on requires them. Not saved since only valid when
reconnect for every game and after restarting. */ connected, and we reconnect for every game and after restarting. */
XP_U16 heartbeat; XP_U16 heartbeat;
XP_U16 nPlayersHere; XP_U16 nPlayersHere;
XP_U16 nPlayersTotal; XP_U16 nPlayersTotal;
XP_Bool connecting;
} r;
XP_Bool isServer; XP_Bool isServer;
XP_Bool connecting;
#ifdef DEBUG #ifdef DEBUG
XP_U16 nUniqueBytes; XP_U16 nUniqueBytes;
#endif #endif
@ -157,12 +161,12 @@ comms_make( MPFORMAL XW_UtilCtxt* util, XP_Bool isServer,
result->util = util; result->util = util;
#ifdef BEYOND_IR #ifdef BEYOND_IR
result->myHostID = isServer? HOST_ID_SERVER: HOST_ID_NONE; result->r.myHostID = isServer? HOST_ID_SERVER: HOST_ID_NONE;
XP_LOGF( "set myHostID to %d", result->myHostID ); XP_LOGF( "set myHostID to %d", result->r.myHostID );
result->relayState = COMMS_RELAYSTATE_UNCONNECTED; result->r.relayState = COMMS_RELAYSTATE_UNCONNECTED;
result->nPlayersHere = nPlayersHere; result->r.nPlayersHere = nPlayersHere;
result->nPlayersTotal = nPlayersTotal; result->r.nPlayersTotal = nPlayersTotal;
#endif #endif
return result; return result;
} /* comms_make */ } /* comms_make */
@ -212,9 +216,9 @@ comms_reset( CommsCtxt* comms, XP_Bool isServer,
comms->connID = CONN_ID_NONE; comms->connID = CONN_ID_NONE;
#ifdef BEYOND_IR #ifdef BEYOND_IR
comms->cookieID = COOKIE_ID_NONE; comms->r.cookieID = COOKIE_ID_NONE;
comms->nPlayersHere = nPlayersHere; comms->r.nPlayersHere = nPlayersHere;
comms->nPlayersTotal = nPlayersTotal; comms->r.nPlayersTotal = nPlayersTotal;
relayConnect( comms ); relayConnect( comms );
#endif #endif
} /* comms_reset */ } /* comms_reset */
@ -297,8 +301,8 @@ comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
comms->connID = stream_getU32( stream ); comms->connID = stream_getU32( stream );
comms->nextChannelNo = stream_getU16( stream ); comms->nextChannelNo = stream_getU16( stream );
comms->myHostID = stream_getU8( stream ); comms->r.myHostID = stream_getU8( stream );
stringFromStreamHere( stream, comms->connName, sizeof(comms->connName) ); stringFromStreamHere( stream, comms->r.connName, sizeof(comms->r.connName) );
#ifdef DEBUG #ifdef DEBUG
comms->nUniqueBytes = stream_getU16( stream ); comms->nUniqueBytes = stream_getU16( stream );
@ -318,7 +322,7 @@ comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
rec->nextMsgID = stream_getU16( stream ); rec->nextMsgID = stream_getU16( stream );
rec->lastMsgReceived = stream_getU16( stream ); rec->lastMsgReceived = stream_getU16( stream );
rec->channelNo = stream_getU16( stream ); rec->channelNo = stream_getU16( stream );
rec->hostID = stream_getU8( stream ); /* unneeded unless RELAY */ rec->r.hostID = stream_getU8( stream ); /* unneeded unless RELAY */
#ifdef DEBUG #ifdef DEBUG
rec->lastACK = stream_getU16( stream ); rec->lastACK = stream_getU16( stream );
@ -360,7 +364,7 @@ comms_start( CommsCtxt* comms )
{ {
#ifdef BEYOND_IR #ifdef BEYOND_IR
if ( comms->addr.conType == COMMS_CONN_RELAY ) { if ( comms->addr.conType == COMMS_CONN_RELAY ) {
comms->relayState = COMMS_RELAYSTATE_UNCONNECTED; comms->r.relayState = COMMS_RELAYSTATE_UNCONNECTED;
relayConnect( comms ); relayConnect( comms );
#ifdef XWFEATURE_BLUETOOTH #ifdef XWFEATURE_BLUETOOTH
} else if ( comms->addr.conType == COMMS_CONN_BT ) { } else if ( comms->addr.conType == COMMS_CONN_BT ) {
@ -416,13 +420,13 @@ comms_writeToStream( CommsCtxt* comms, XWStreamCtxt* stream )
MsgQueueElem* msg; MsgQueueElem* msg;
stream_putU8( stream, (XP_U8)comms->isServer ); stream_putU8( stream, (XP_U8)comms->isServer );
stream_putBits( stream, 4, comms->nPlayersHere ); stream_putBits( stream, 4, comms->r.nPlayersHere );
stream_putBits( stream, 4, comms->nPlayersTotal ); stream_putBits( stream, 4, comms->r.nPlayersTotal );
stream_putU32( stream, comms->connID ); stream_putU32( stream, comms->connID );
stream_putU16( stream, comms->nextChannelNo ); stream_putU16( stream, comms->nextChannelNo );
stream_putU8( stream, comms->myHostID ); stream_putU8( stream, comms->r.myHostID );
stringToStream( stream, comms->connName ); stringToStream( stream, comms->r.connName );
#ifdef DEBUG #ifdef DEBUG
stream_putU16( stream, comms->nUniqueBytes ); stream_putU16( stream, comms->nUniqueBytes );
@ -442,7 +446,7 @@ comms_writeToStream( CommsCtxt* comms, XWStreamCtxt* stream )
stream_putU16( stream, (XP_U16)rec->nextMsgID ); stream_putU16( stream, (XP_U16)rec->nextMsgID );
stream_putU16( stream, (XP_U16)rec->lastMsgReceived ); stream_putU16( stream, (XP_U16)rec->lastMsgReceived );
stream_putU16( stream, rec->channelNo ); stream_putU16( stream, rec->channelNo );
stream_putU8( stream, rec->hostID ); /* unneeded unless RELAY */ stream_putU8( stream, rec->r.hostID ); /* unneeded unless RELAY */
#ifdef DEBUG #ifdef DEBUG
stream_putU16( stream, rec->lastACK ); stream_putU16( stream, rec->lastACK );
stream_putU16( stream, rec->nUniqueBytes ); stream_putU16( stream, rec->nUniqueBytes );
@ -683,7 +687,7 @@ sendMsg( CommsCtxt* comms, MsgQueueElem* elem )
if ( 0 ) { if ( 0 ) {
#ifdef BEYOND_IR #ifdef BEYOND_IR
} else if ( comms_getConType( comms ) == COMMS_CONN_RELAY ) { } else if ( comms_getConType( comms ) == COMMS_CONN_RELAY ) {
if ( comms->relayState == COMMS_RELAYSTATE_ALLCONNECTED ) { if ( comms->r.relayState == COMMS_RELAYSTATE_ALLCONNECTED ) {
XWHostID destID = getDestID( comms, channelNo ); XWHostID destID = getDestID( comms, channelNo );
result = send_via_relay( comms, XWRELAY_MSG_TORELAY, destID, result = send_via_relay( comms, XWRELAY_MSG_TORELAY, destID,
elem->msg, elem->len ); elem->msg, elem->len );
@ -740,25 +744,25 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
case XWRELAY_CONNECT_RESP: case XWRELAY_CONNECT_RESP:
case XWRELAY_RECONNECT_RESP: case XWRELAY_RECONNECT_RESP:
comms->relayState = COMMS_RELAYSTATE_CONNECTED; comms->r.relayState = COMMS_RELAYSTATE_CONNECTED;
comms->heartbeat = stream_getU16( stream ); comms->r.heartbeat = stream_getU16( stream );
comms->cookieID = stream_getU16( stream ); comms->r.cookieID = stream_getU16( stream );
comms->myHostID = (XWHostID)stream_getU8( stream ); comms->r.myHostID = (XWHostID)stream_getU8( stream );
XP_LOGF( "got XWRELAY_CONNECTRESP; set cookieID = %d; " XP_LOGF( "got XWRELAY_CONNECTRESP; set cookieID = %d; "
"set hostid: %x", "set hostid: %x",
comms->cookieID, comms->myHostID ); comms->r.cookieID, comms->r.myHostID );
setHeartbeatTimer( comms ); setHeartbeatTimer( comms );
break; break;
case XWRELAY_ALLHERE: case XWRELAY_ALLHERE:
comms->relayState = COMMS_RELAYSTATE_ALLCONNECTED; comms->r.relayState = COMMS_RELAYSTATE_ALLCONNECTED;
hasName = stream_getU8( stream ); hasName = stream_getU8( stream );
if ( hasName ) { if ( hasName ) {
stringFromStreamHere( stream, comms->connName, stringFromStreamHere( stream, comms->r.connName,
sizeof(comms->connName) ); sizeof(comms->r.connName) );
XP_LOGF( "read connName: %s", comms->connName ); XP_LOGF( "read connName: %s", comms->r.connName );
} else { } else {
XP_ASSERT( comms->connName[0] != '\0' ); XP_ASSERT( comms->r.connName[0] != '\0' );
} }
/* We're [re-]connected now. Send any pending messages. This may /* We're [re-]connected now. Send any pending messages. This may
@ -773,8 +777,8 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
XP_LOGF( "cookieID: %d; srcID: %x; destID: %x", XP_LOGF( "cookieID: %d; srcID: %x; destID: %x",
cookieID, srcID, destID ); cookieID, srcID, destID );
/* If these values don't check out, drop it */ /* If these values don't check out, drop it */
consumed = cookieID != comms->cookieID consumed = cookieID != comms->r.cookieID
|| destID != comms->myHostID; || destID != comms->r.myHostID;
if ( consumed ) { if ( consumed ) {
XP_LOGF( "rejecting data message" ); XP_LOGF( "rejecting data message" );
} else { } else {
@ -795,7 +799,7 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
XP_LOGF( "XWRELAY_DISCONNECT_YOU|XWRELAY_CONNECTDENIED" ); XP_LOGF( "XWRELAY_DISCONNECT_YOU|XWRELAY_CONNECTDENIED" );
relayErr = stream_getU8( stream ); relayErr = stream_getU8( stream );
util_userError( comms->util, ERR_RELAY_BASE + relayErr ); util_userError( comms->util, ERR_RELAY_BASE + relayErr );
comms->relayState = COMMS_RELAYSTATE_UNCONNECTED; comms->r.relayState = COMMS_RELAYSTATE_UNCONNECTED;
/* fallthru */ /* fallthru */
default: default:
XP_LOGF( "dropping relay msg with cmd %d", (XP_U16)cmd ); XP_LOGF( "dropping relay msg with cmd %d", (XP_U16)cmd );
@ -949,7 +953,7 @@ p_comms_timerFired( void* closure, XWTimerReason XP_UNUSED_DBG(why) )
CommsCtxt* comms = (CommsCtxt*)closure; CommsCtxt* comms = (CommsCtxt*)closure;
XP_ASSERT( why == TIMER_HEARTBEAT ); XP_ASSERT( why == TIMER_HEARTBEAT );
XP_LOGF( "comms_timerFired" ); XP_LOGF( "comms_timerFired" );
if ( comms->heartbeat != HEARTBEAT_NONE ) { if ( comms->r.heartbeat != HEARTBEAT_NONE ) {
send_via_relay( comms, XWRELAY_HEARTBEAT, HOST_ID_NONE, NULL, 0 ); send_via_relay( comms, XWRELAY_HEARTBEAT, HOST_ID_NONE, NULL, 0 );
/* No need to reset timer. send_via_relay does that. */ /* No need to reset timer. send_via_relay does that. */
} }
@ -958,7 +962,7 @@ p_comms_timerFired( void* closure, XWTimerReason XP_UNUSED_DBG(why) )
static void static void
setHeartbeatTimer( CommsCtxt* comms ) setHeartbeatTimer( CommsCtxt* comms )
{ {
util_setTimer( comms->util, TIMER_HEARTBEAT, comms->heartbeat, util_setTimer( comms->util, TIMER_HEARTBEAT, comms->r.heartbeat,
p_comms_timerFired, comms ); p_comms_timerFired, comms );
} }
#endif #endif
@ -1023,7 +1027,7 @@ rememberChannelAddress( CommsCtxt* comms, XP_PlayerAddr channelNo,
recs->nextMsgID = 0; recs->nextMsgID = 0;
recs->channelNo = channelNo; recs->channelNo = channelNo;
recs->hostID = hostID; recs->r.hostID = hostID;
#ifdef DEBUG #ifdef DEBUG
recs->nUniqueBytes = 0; recs->nUniqueBytes = 0;
#endif #endif
@ -1036,7 +1040,7 @@ rememberChannelAddress( CommsCtxt* comms, XP_PlayerAddr channelNo,
if ( !!recs ) { if ( !!recs ) {
if ( !!addr ) { if ( !!addr ) {
XP_MEMCPY( &recs->addr, addr, sizeof(recs->addr) ); XP_MEMCPY( &recs->addr, addr, sizeof(recs->addr) );
XP_ASSERT( recs->hostID == hostID ); XP_ASSERT( recs->r.hostID == hostID );
} else { } else {
XP_MEMSET( &recs->addr, 0, sizeof(recs->addr) ); XP_MEMSET( &recs->addr, 0, sizeof(recs->addr) );
recs->addr.conType = comms->addr.conType; recs->addr.conType = comms->addr.conType;
@ -1098,7 +1102,7 @@ getDestID( CommsCtxt* comms, XP_PlayerAddr channelNo )
AddressRecord* recs; AddressRecord* recs;
for ( recs = comms->recs; !!recs; recs = recs->next ) { for ( recs = comms->recs; !!recs; recs = recs->next ) {
if ( recs->channelNo == channelNo ) { if ( recs->channelNo == channelNo ) {
id = recs->hostID; id = recs->r.hostID;
} }
} }
} }
@ -1127,8 +1131,8 @@ send_via_relay( CommsCtxt* comms, XWRELAY_Cmd cmd, XWHostID destID,
switch ( cmd ) { switch ( cmd ) {
case XWRELAY_MSG_TORELAY: case XWRELAY_MSG_TORELAY:
stream_putU16( tmpStream, comms->cookieID ); stream_putU16( tmpStream, comms->r.cookieID );
stream_putU8( tmpStream, comms->myHostID ); stream_putU8( tmpStream, comms->r.myHostID );
stream_putU8( tmpStream, destID ); stream_putU8( tmpStream, destID );
if ( data != NULL && dlen > 0 ) { if ( data != NULL && dlen > 0 ) {
stream_putBytes( tmpStream, data, dlen ); stream_putBytes( tmpStream, data, dlen );
@ -1137,33 +1141,33 @@ send_via_relay( CommsCtxt* comms, XWRELAY_Cmd cmd, XWHostID destID,
case XWRELAY_GAME_CONNECT: case XWRELAY_GAME_CONNECT:
stream_putU8( tmpStream, XWRELAY_PROTO_VERSION ); stream_putU8( tmpStream, XWRELAY_PROTO_VERSION );
stringToStream( tmpStream, addr.u.ip_relay.cookie ); stringToStream( tmpStream, addr.u.ip_relay.cookie );
stream_putU8( tmpStream, comms->myHostID ); stream_putU8( tmpStream, comms->r.myHostID );
stream_putU8( tmpStream, comms->nPlayersHere ); stream_putU8( tmpStream, comms->r.nPlayersHere );
stream_putU8( tmpStream, comms->nPlayersTotal ); stream_putU8( tmpStream, comms->r.nPlayersTotal );
comms->relayState = COMMS_RELAYSTATE_CONNECT_PENDING; comms->r.relayState = COMMS_RELAYSTATE_CONNECT_PENDING;
break; break;
case XWRELAY_GAME_RECONNECT: case XWRELAY_GAME_RECONNECT:
stream_putU8( tmpStream, XWRELAY_PROTO_VERSION ); stream_putU8( tmpStream, XWRELAY_PROTO_VERSION );
stream_putU8( tmpStream, comms->myHostID ); stream_putU8( tmpStream, comms->r.myHostID );
stream_putU8( tmpStream, comms->nPlayersHere ); stream_putU8( tmpStream, comms->r.nPlayersHere );
stream_putU8( tmpStream, comms->nPlayersTotal ); stream_putU8( tmpStream, comms->r.nPlayersTotal );
stringToStream( tmpStream, comms->connName ); stringToStream( tmpStream, comms->r.connName );
comms->relayState = COMMS_RELAYSTATE_CONNECT_PENDING; comms->r.relayState = COMMS_RELAYSTATE_CONNECT_PENDING;
break; break;
case XWRELAY_GAME_DISCONNECT: case XWRELAY_GAME_DISCONNECT:
stream_putU16( tmpStream, comms->cookieID ); stream_putU16( tmpStream, comms->r.cookieID );
stream_putU8( tmpStream, comms->myHostID ); stream_putU8( tmpStream, comms->r.myHostID );
break; break;
case XWRELAY_HEARTBEAT: case XWRELAY_HEARTBEAT:
/* Add these for grins. Server can assert they match the IP /* Add these for grins. Server can assert they match the IP
address it expects 'em on. */ address it expects 'em on. */
stream_putU16( tmpStream, comms->cookieID ); stream_putU16( tmpStream, comms->r.cookieID );
stream_putU8( tmpStream, comms->myHostID ); stream_putU8( tmpStream, comms->r.myHostID );
break; break;
default: default:
@ -1198,13 +1202,13 @@ static void
relayConnect( CommsCtxt* comms ) relayConnect( CommsCtxt* comms )
{ {
XP_LOGF( "relayConnect called" ); XP_LOGF( "relayConnect called" );
if ( comms->addr.conType == COMMS_CONN_RELAY && !comms->connecting ) { if ( comms->addr.conType == COMMS_CONN_RELAY && !comms->r.connecting ) {
comms->connecting = XP_TRUE; comms->r.connecting = XP_TRUE;
send_via_relay( comms, send_via_relay( comms,
comms->connName[0] == '\0' ? comms->r.connName[0] == '\0' ?
XWRELAY_GAME_CONNECT:XWRELAY_GAME_RECONNECT, XWRELAY_GAME_CONNECT:XWRELAY_GAME_RECONNECT,
comms->myHostID, NULL, 0 ); comms->r.myHostID, NULL, 0 );
comms->connecting = XP_FALSE; comms->r.connecting = XP_FALSE;
} }
} /* relayConnect */ } /* relayConnect */
@ -1228,8 +1232,8 @@ relayDisconnect( CommsCtxt* comms )
#ifdef BEYOND_IR #ifdef BEYOND_IR
XP_LOGF( "relayDisconnect called" ); XP_LOGF( "relayDisconnect called" );
if ( comms->addr.conType == COMMS_CONN_RELAY ) { if ( comms->addr.conType == COMMS_CONN_RELAY ) {
if ( comms->relayState != COMMS_RELAYSTATE_UNCONNECTED ) { if ( comms->r.relayState != COMMS_RELAYSTATE_UNCONNECTED ) {
comms->relayState = COMMS_RELAYSTATE_UNCONNECTED; comms->r.relayState = COMMS_RELAYSTATE_UNCONNECTED;
send_via_relay( comms, XWRELAY_GAME_DISCONNECT, HOST_ID_NONE, send_via_relay( comms, XWRELAY_GAME_DISCONNECT, HOST_ID_NONE,
NULL, 0 ); NULL, 0 );
} }