- Segfault unter hoher Netzaktivitaet behoben: in Conn_Close() wird die
Connection-Struktur nun frueher als "ungueltig" markiert. - besseres Error-Logging.
This commit is contained in:
parent
c49bee8d0b
commit
3cf845fbfb
|
@ -9,7 +9,7 @@
|
||||||
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
|
||||||
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
|
||||||
*
|
*
|
||||||
* $Id: conn.c,v 1.81 2002/10/10 15:01:12 alex Exp $
|
* $Id: conn.c,v 1.82 2002/10/14 22:21:00 alex Exp $
|
||||||
*
|
*
|
||||||
* connect.h: Verwaltung aller Netz-Verbindungen ("connections")
|
* connect.h: Verwaltung aller Netz-Verbindungen ("connections")
|
||||||
*/
|
*/
|
||||||
|
@ -236,7 +236,7 @@ Conn_Handler( VOID )
|
||||||
fd_set read_sockets, write_sockets;
|
fd_set read_sockets, write_sockets;
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
time_t start, t;
|
time_t start, t;
|
||||||
INT i;
|
INT i, idx;
|
||||||
|
|
||||||
start = time( NULL );
|
start = time( NULL );
|
||||||
while(( ! NGIRCd_Quit ) && ( ! NGIRCd_Restart ))
|
while(( ! NGIRCd_Quit ) && ( ! NGIRCd_Restart ))
|
||||||
|
@ -318,7 +318,7 @@ Conn_Handler( VOID )
|
||||||
/* Fehler (z.B. Interrupt) */
|
/* Fehler (z.B. Interrupt) */
|
||||||
if( errno != EINTR )
|
if( errno != EINTR )
|
||||||
{
|
{
|
||||||
Log( LOG_EMERG, "select(): %s!", strerror( errno ));
|
Log( LOG_EMERG, "Conn_Handler: select(): %s!", strerror( errno ));
|
||||||
Log( LOG_ALERT, "%s exiting due to fatal errors!", PACKAGE );
|
Log( LOG_ALERT, "%s exiting due to fatal errors!", PACKAGE );
|
||||||
exit( 1 );
|
exit( 1 );
|
||||||
}
|
}
|
||||||
|
@ -328,7 +328,18 @@ Conn_Handler( VOID )
|
||||||
/* Koennen Daten geschrieben werden? */
|
/* Koennen Daten geschrieben werden? */
|
||||||
for( i = 0; i < Conn_MaxFD + 1; i++ )
|
for( i = 0; i < Conn_MaxFD + 1; i++ )
|
||||||
{
|
{
|
||||||
if( FD_ISSET( i, &write_sockets )) Handle_Write( Socket2Index( i ));
|
if( ! FD_ISSET( i, &write_sockets )) continue;
|
||||||
|
|
||||||
|
/* Es kann geschrieben werden ... */
|
||||||
|
idx = Socket2Index( i );
|
||||||
|
if( ! idx ) continue;
|
||||||
|
|
||||||
|
if( ! Handle_Write( idx ))
|
||||||
|
{
|
||||||
|
/* Fehler beim Schreiben! Diesen Socket nun
|
||||||
|
* auch aus dem Read-Set entfernen: */
|
||||||
|
FD_CLR( i, &read_sockets );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Daten zum Lesen vorhanden? */
|
/* Daten zum Lesen vorhanden? */
|
||||||
|
@ -466,12 +477,17 @@ Conn_Close( CONN_ID Idx, CHAR *LogMsg, CHAR *FwdMsg, BOOLEAN InformClient )
|
||||||
|
|
||||||
if( close( My_Connections[Idx].sock ) != 0 )
|
if( close( My_Connections[Idx].sock ) != 0 )
|
||||||
{
|
{
|
||||||
Log( LOG_ERR, "Error closing connection %d with %s:%d - %s!", Idx, inet_ntoa( My_Connections[Idx].addr.sin_addr ), ntohs( My_Connections[Idx].addr.sin_port), strerror( errno ));
|
Log( LOG_ERR, "Error closing connection %d (socket %d) with %s:%d - %s!", Idx, My_Connections[Idx].sock, inet_ntoa( My_Connections[Idx].addr.sin_addr ), ntohs( My_Connections[Idx].addr.sin_port), strerror( errno ));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Log( LOG_INFO, "Connection %d with %s:%d closed.", Idx, inet_ntoa( My_Connections[Idx].addr.sin_addr ), ntohs( My_Connections[Idx].addr.sin_port ));
|
Log( LOG_INFO, "Connection %d (socket %d) with %s:%d closed.", Idx, My_Connections[Idx].sock, inet_ntoa( My_Connections[Idx].addr.sin_addr ), ntohs( My_Connections[Idx].addr.sin_port ));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Socket als "ungueltig" markieren */
|
||||||
|
FD_CLR( My_Connections[Idx].sock, &My_Sockets );
|
||||||
|
FD_CLR( My_Connections[Idx].sock, &My_Connects );
|
||||||
|
My_Connections[Idx].sock = NONE;
|
||||||
|
|
||||||
if( c ) Client_Destroy( c, LogMsg, FwdMsg, TRUE );
|
if( c ) Client_Destroy( c, LogMsg, FwdMsg, TRUE );
|
||||||
|
|
||||||
|
@ -494,9 +510,8 @@ Conn_Close( CONN_ID Idx, CHAR *LogMsg, CHAR *FwdMsg, BOOLEAN InformClient )
|
||||||
Conf_Server[My_Connections[Idx].our_server].lasttry = time( NULL ) - Conf_ConnectRetry + RECONNECT_DELAY;
|
Conf_Server[My_Connections[Idx].our_server].lasttry = time( NULL ) - Conf_ConnectRetry + RECONNECT_DELAY;
|
||||||
}
|
}
|
||||||
|
|
||||||
FD_CLR( My_Connections[Idx].sock, &My_Sockets );
|
/* Connection-Struktur loeschen (=freigeben) */
|
||||||
FD_CLR( My_Connections[Idx].sock, &My_Connects );
|
Init_Conn_Struct( Idx );
|
||||||
My_Connections[Idx].sock = NONE;
|
|
||||||
} /* Conn_Close */
|
} /* Conn_Close */
|
||||||
|
|
||||||
|
|
||||||
|
@ -575,7 +590,7 @@ Try_Write( CONN_ID Idx )
|
||||||
/* Fehler! */
|
/* Fehler! */
|
||||||
if( errno != EINTR )
|
if( errno != EINTR )
|
||||||
{
|
{
|
||||||
Log( LOG_ALERT, "select() failed: %s!", strerror( errno ));
|
Log( LOG_ALERT, "Try_Write: select() failed: %s (con=%d, sock=%d)!", strerror( errno ), Idx, My_Connections[Idx].sock );
|
||||||
Conn_Close( Idx, "Server error!", NULL, FALSE );
|
Conn_Close( Idx, "Server error!", NULL, FALSE );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -616,7 +631,8 @@ Handle_Read( INT Sock )
|
||||||
/* Ein Client Socket: entweder ein User oder Server */
|
/* Ein Client Socket: entweder ein User oder Server */
|
||||||
|
|
||||||
idx = Socket2Index( Sock );
|
idx = Socket2Index( Sock );
|
||||||
Read_Request( idx );
|
if( idx > NONE ) Read_Request( idx );
|
||||||
|
else Log( LOG_DEBUG, "Handle_Read: can't get connection for socket %d!", Sock );
|
||||||
}
|
}
|
||||||
} /* Handle_Read */
|
} /* Handle_Read */
|
||||||
|
|
||||||
|
@ -628,7 +644,7 @@ Handle_Write( CONN_ID Idx )
|
||||||
|
|
||||||
INT len, res, err;
|
INT len, res, err;
|
||||||
|
|
||||||
assert( Idx >= 0 );
|
assert( Idx >= NONE );
|
||||||
assert( My_Connections[Idx].sock > NONE );
|
assert( My_Connections[Idx].sock > NONE );
|
||||||
|
|
||||||
if( FD_ISSET( My_Connections[Idx].sock, &My_Connects ))
|
if( FD_ISSET( My_Connections[Idx].sock, &My_Connects ))
|
||||||
|
@ -664,9 +680,7 @@ Handle_Write( CONN_ID Idx )
|
||||||
|
|
||||||
/* PASS und SERVER verschicken */
|
/* PASS und SERVER verschicken */
|
||||||
Conn_WriteStr( Idx, "PASS %s %s", Conf_Server[My_Connections[Idx].our_server].pwd, NGIRCd_ProtoID );
|
Conn_WriteStr( Idx, "PASS %s %s", Conf_Server[My_Connections[Idx].our_server].pwd, NGIRCd_ProtoID );
|
||||||
Conn_WriteStr( Idx, "SERVER %s :%s", Conf_ServerName, Conf_ServerInfo );
|
return Conn_WriteStr( Idx, "SERVER %s :%s", Conf_ServerName, Conf_ServerInfo );
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
assert( My_Connections[Idx].wdatalen > 0 );
|
assert( My_Connections[Idx].wdatalen > 0 );
|
||||||
|
@ -676,8 +690,8 @@ Handle_Write( CONN_ID Idx )
|
||||||
if( len < 0 )
|
if( len < 0 )
|
||||||
{
|
{
|
||||||
/* Oops, ein Fehler! */
|
/* Oops, ein Fehler! */
|
||||||
Log( LOG_ERR, "Write error (buffer) on connection %d: %s!", Idx, strerror( errno ));
|
Log( LOG_ERR, "Write error on connection %d (socket %d): %s!", Idx, My_Connections[Idx].sock, strerror( errno ));
|
||||||
Conn_Close( Idx, "Write error (buffer)!", NULL, FALSE );
|
Conn_Close( Idx, "Write error!", NULL, FALSE );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -714,7 +728,7 @@ New_Connection( INT Sock )
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Freie Connection-Struktur suschen */
|
/* Freie Connection-Struktur suchen */
|
||||||
for( idx = 0; idx < MAX_CONNECTIONS; idx++ ) if( My_Connections[idx].sock == NONE ) break;
|
for( idx = 0; idx < MAX_CONNECTIONS; idx++ ) if( My_Connections[idx].sock == NONE ) break;
|
||||||
if( idx >= MAX_CONNECTIONS )
|
if( idx >= MAX_CONNECTIONS )
|
||||||
{
|
{
|
||||||
|
@ -774,8 +788,8 @@ Socket2Index( INT Sock )
|
||||||
|
|
||||||
for( idx = 0; idx < MAX_CONNECTIONS; idx++ ) if( My_Connections[idx].sock == Sock ) break;
|
for( idx = 0; idx < MAX_CONNECTIONS; idx++ ) if( My_Connections[idx].sock == Sock ) break;
|
||||||
|
|
||||||
assert( idx < MAX_CONNECTIONS );
|
if( idx >= MAX_CONNECTIONS ) return NONE;
|
||||||
return idx;
|
else return idx;
|
||||||
} /* Socket2Index */
|
} /* Socket2Index */
|
||||||
|
|
||||||
|
|
||||||
|
@ -811,7 +825,7 @@ Read_Request( CONN_ID Idx )
|
||||||
if( len < 0 )
|
if( len < 0 )
|
||||||
{
|
{
|
||||||
/* Fehler beim Lesen */
|
/* Fehler beim Lesen */
|
||||||
Log( LOG_ERR, "Read error on connection %d: %s!", Idx, strerror( errno ));
|
Log( LOG_ERR, "Read error on connection %d (socket %d): %s!", Idx, My_Connections[Idx].sock, strerror( errno ));
|
||||||
Conn_Close( Idx, "Read error!", "Client closed connection", FALSE );
|
Conn_Close( Idx, "Read error!", "Client closed connection", FALSE );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue