os: eliminate fd value limits for clients
With no code depending on the range of file descriptors, checking for that can be eliminated. Signed-off-by: Keith Packard <keithp@keithp.com> Reviewed-by: Adam Jackson <ajax@redhat.com>
This commit is contained in:
		
							parent
							
								
									30bc0732f9
								
							
						
					
					
						commit
						e0edb963fe
					
				|  | @ -104,7 +104,6 @@ SOFTWARE. | ||||||
| #endif                          /* WIN32 */ | #endif                          /* WIN32 */ | ||||||
| #include "misc.h"               /* for typedef of pointer */ | #include "misc.h"               /* for typedef of pointer */ | ||||||
| #include "osdep.h" | #include "osdep.h" | ||||||
| #include <X11/Xpoll.h> |  | ||||||
| #include "opaque.h" | #include "opaque.h" | ||||||
| #include "dixstruct.h" | #include "dixstruct.h" | ||||||
| #include "xace.h" | #include "xace.h" | ||||||
|  | @ -120,7 +119,6 @@ SOFTWARE. | ||||||
| 
 | 
 | ||||||
| #include "probes.h" | #include "probes.h" | ||||||
| 
 | 
 | ||||||
| static int lastfdesc;           /* maximum file descriptor */ |  | ||||||
| struct ospoll   *server_poll; | struct ospoll   *server_poll; | ||||||
| 
 | 
 | ||||||
| int MaxClients = 0; | int MaxClients = 0; | ||||||
|  | @ -134,8 +132,6 @@ static char dynamic_display[7]; /* display name */ | ||||||
| Bool PartialNetwork;            /* continue even if unable to bind all addrs */ | Bool PartialNetwork;            /* continue even if unable to bind all addrs */ | ||||||
| static Pid_t ParentProcess; | static Pid_t ParentProcess; | ||||||
| 
 | 
 | ||||||
| static Bool debug_conns = FALSE; |  | ||||||
| 
 |  | ||||||
| int GrabInProgress = 0; | int GrabInProgress = 0; | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
|  | @ -149,19 +145,15 @@ set_poll_clients(void); | ||||||
| 
 | 
 | ||||||
| #if !defined(WIN32) | #if !defined(WIN32) | ||||||
| int *ConnectionTranslation = NULL; | int *ConnectionTranslation = NULL; | ||||||
|  | int ConnectionTranslationSize = 0; | ||||||
| #else | #else | ||||||
| /*
 | /*
 | ||||||
|  * On NT fds are not between 0 and MAXSOCKS, they are unrelated, and there is |  * On NT fds are not small integers, they are unrelated, and there is | ||||||
|  * not even a known maximum value, so use something quite arbitrary for now. |  * not even a known maximum value, so use something quite arbitrary for now. | ||||||
|  * Do storage is a hash table of size 256. Collisions are handled in a linked |  * Do storage is a hash table of size 256. Collisions are handled in a linked | ||||||
|  * list. |  * list. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #undef MAXSOCKS |  | ||||||
| #define MAXSOCKS 512 |  | ||||||
| #undef MAXSELECT |  | ||||||
| #define MAXSELECT 512 |  | ||||||
| 
 |  | ||||||
| struct _ct_node { | struct _ct_node { | ||||||
|     struct _ct_node *next; |     struct _ct_node *next; | ||||||
|     int key; |     int key; | ||||||
|  | @ -266,47 +258,17 @@ lookup_trans_conn(int fd) | ||||||
| void | void | ||||||
| InitConnectionLimits(void) | InitConnectionLimits(void) | ||||||
| { | { | ||||||
|     lastfdesc = -1; |     MaxClients = MAXCLIENTS; | ||||||
| 
 |  | ||||||
| #ifndef __CYGWIN__ |  | ||||||
| 
 |  | ||||||
| #if !defined(XNO_SYSCONF) && defined(_SC_OPEN_MAX) |  | ||||||
|     lastfdesc = sysconf(_SC_OPEN_MAX) - 1; |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef HAVE_GETDTABLESIZE |  | ||||||
|     if (lastfdesc < 0) |  | ||||||
|         lastfdesc = getdtablesize() - 1; |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #ifdef _NFILE |  | ||||||
|     if (lastfdesc < 0) |  | ||||||
|         lastfdesc = _NFILE - 1; |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #endif                          /* __CYGWIN__ */ |  | ||||||
| 
 |  | ||||||
|     /* This is the fallback */ |  | ||||||
|     if (lastfdesc < 0) |  | ||||||
|         lastfdesc = MAXSOCKS; |  | ||||||
| 
 |  | ||||||
|     if (lastfdesc > MAXSELECT) |  | ||||||
|         lastfdesc = MAXSELECT; |  | ||||||
| 
 |  | ||||||
|     if (lastfdesc > MAXCLIENTS) { |  | ||||||
|         lastfdesc = MAXCLIENTS; |  | ||||||
|         if (debug_conns) |  | ||||||
|             ErrorF("REACHED MAXIMUM CLIENTS LIMIT %d\n", LimitClients); |  | ||||||
|     } |  | ||||||
|     MaxClients = lastfdesc; |  | ||||||
| 
 | 
 | ||||||
| #ifdef DEBUG | #ifdef DEBUG | ||||||
|     ErrorF("InitConnectionLimits: MaxClients = %d\n", MaxClients); |     ErrorF("InitConnectionLimits: MaxClients = %d\n", MaxClients); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #if !defined(WIN32) | #if !defined(WIN32) | ||||||
|     if (!ConnectionTranslation) |     if (!ConnectionTranslation) { | ||||||
|         ConnectionTranslation = xnfallocarray(lastfdesc + 1, sizeof(int)); |         ConnectionTranslation = xnfallocarray(MaxClients, sizeof(int)); | ||||||
|  |         ConnectionTranslationSize = MaxClients; | ||||||
|  |     } | ||||||
| #else | #else | ||||||
|     InitConnectionTranslation(); |     InitConnectionTranslation(); | ||||||
| #endif | #endif | ||||||
|  | @ -385,7 +347,7 @@ CreateWellKnownSockets(void) | ||||||
|     int partial; |     int partial; | ||||||
| 
 | 
 | ||||||
| #if !defined(WIN32) | #if !defined(WIN32) | ||||||
|     for (i = 0; i < MaxClients; i++) |     for (i = 0; i < ConnectionTranslationSize; i++) | ||||||
|         ConnectionTranslation[i] = 0; |         ConnectionTranslation[i] = 0; | ||||||
| #else | #else | ||||||
|     ClearConnectionTranslation(); |     ClearConnectionTranslation(); | ||||||
|  | @ -761,14 +723,6 @@ AllocNewConnection(XtransConnInfo trans_conn, int fd, CARD32 conn_time) | ||||||
|     OsCommPtr oc; |     OsCommPtr oc; | ||||||
|     ClientPtr client; |     ClientPtr client; | ||||||
| 
 | 
 | ||||||
|     if ( |  | ||||||
| #ifndef WIN32 |  | ||||||
|            fd >= lastfdesc |  | ||||||
| #else |  | ||||||
|            XFD_SETCOUNT(&AllClients) >= MaxClients |  | ||||||
| #endif |  | ||||||
|         ) |  | ||||||
|         return NullClient; |  | ||||||
|     oc = malloc(sizeof(OsCommRec)); |     oc = malloc(sizeof(OsCommRec)); | ||||||
|     if (!oc) |     if (!oc) | ||||||
|         return NullClient; |         return NullClient; | ||||||
|  | @ -785,6 +739,10 @@ AllocNewConnection(XtransConnInfo trans_conn, int fd, CARD32 conn_time) | ||||||
|     } |     } | ||||||
|     client->local = ComputeLocalClient(client); |     client->local = ComputeLocalClient(client); | ||||||
| #if !defined(WIN32) | #if !defined(WIN32) | ||||||
|  |     if (fd >= ConnectionTranslationSize) { | ||||||
|  |         ConnectionTranslationSize *= 2; | ||||||
|  |         ConnectionTranslation = xnfreallocarray(ConnectionTranslation, ConnectionTranslationSize, sizeof (int)); | ||||||
|  |     } | ||||||
|     ConnectionTranslation[fd] = client->index; |     ConnectionTranslation[fd] = client->index; | ||||||
| #else | #else | ||||||
|     SetConnectionTranslation(fd, client->index); |     SetConnectionTranslation(fd, client->index); | ||||||
|  | @ -824,6 +782,7 @@ EstablishNewConnections(ClientPtr clientUnused, void *closure) | ||||||
|     OsCommPtr oc; |     OsCommPtr oc; | ||||||
|     XtransConnInfo trans_conn, new_trans_conn; |     XtransConnInfo trans_conn, new_trans_conn; | ||||||
|     int status; |     int status; | ||||||
|  |     int clientid; | ||||||
| 
 | 
 | ||||||
|     connect_time = GetTimeInMillis(); |     connect_time = GetTimeInMillis(); | ||||||
|     /* kill off stragglers */ |     /* kill off stragglers */ | ||||||
|  | @ -845,17 +804,9 @@ EstablishNewConnections(ClientPtr clientUnused, void *closure) | ||||||
| 
 | 
 | ||||||
|     newconn = _XSERVTransGetConnectionNumber(new_trans_conn); |     newconn = _XSERVTransGetConnectionNumber(new_trans_conn); | ||||||
| 
 | 
 | ||||||
|     if (newconn < lastfdesc) { |     clientid = GetConnectionTranslation(newconn); | ||||||
|         int clientid; |     if (clientid && (client = clients[clientid])) | ||||||
| 
 |         CloseDownClient(client); | ||||||
| #if !defined(WIN32) |  | ||||||
|         clientid = ConnectionTranslation[newconn]; |  | ||||||
| #else |  | ||||||
|         clientid = GetConnectionTranslation(newconn); |  | ||||||
| #endif |  | ||||||
|         if (clientid && (client = clients[clientid])) |  | ||||||
|             CloseDownClient(client); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     _XSERVTransSetOption(new_trans_conn, TRANS_NONBLOCKING, 1); |     _XSERVTransSetOption(new_trans_conn, TRANS_NONBLOCKING, 1); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										42
									
								
								os/osdep.h
								
								
								
								
							
							
						
						
									
										42
									
								
								os/osdep.h
								
								
								
								
							|  | @ -63,42 +63,8 @@ SOFTWARE. | ||||||
| #undef _POSIX_SOURCE | #undef _POSIX_SOURCE | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifndef OPEN_MAX |  | ||||||
| #ifdef SVR4 |  | ||||||
| #define OPEN_MAX 512 |  | ||||||
| #else |  | ||||||
| #include <sys/param.h> |  | ||||||
| #ifndef OPEN_MAX |  | ||||||
| #if defined(NOFILE) && !defined(NOFILES_MAX) |  | ||||||
| #define OPEN_MAX NOFILE |  | ||||||
| #else |  | ||||||
| #if !defined(WIN32) || defined(__CYGWIN__) |  | ||||||
| #define OPEN_MAX NOFILES_MAX |  | ||||||
| #else |  | ||||||
| #define OPEN_MAX 512 |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #include <X11/Xpoll.h> |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * MAXSOCKS is used only for initialising MaxClients when no other method |  | ||||||
|  * like sysconf(_SC_OPEN_MAX) is not supported. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #if OPEN_MAX <= 512 |  | ||||||
| #define MAXSOCKS (OPEN_MAX - 1) |  | ||||||
| #else |  | ||||||
| #define MAXSOCKS 512 |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| /* MAXSELECT is the number of fds that select() can handle */ |  | ||||||
| #define MAXSELECT (sizeof(fd_set) * NBBY) |  | ||||||
| 
 |  | ||||||
| #include <stddef.h> | #include <stddef.h> | ||||||
|  | #include <X11/Xos.h> | ||||||
| 
 | 
 | ||||||
| /* If EAGAIN and EWOULDBLOCK are distinct errno values, then we check errno
 | /* If EAGAIN and EWOULDBLOCK are distinct errno values, then we check errno
 | ||||||
|  * for both EAGAIN and EWOULDBLOCK, because some supposedly POSIX |  * for both EAGAIN and EWOULDBLOCK, because some supposedly POSIX | ||||||
|  | @ -187,6 +153,12 @@ listen_to_client(ClientPtr client); | ||||||
| 
 | 
 | ||||||
| #if !defined(WIN32) || defined(__CYGWIN__) | #if !defined(WIN32) || defined(__CYGWIN__) | ||||||
| extern int *ConnectionTranslation; | extern int *ConnectionTranslation; | ||||||
|  | extern int ConnectionTranslationSize; | ||||||
|  | static inline int GetConnectionTranslation(int conn) { | ||||||
|  |     if (conn >= ConnectionTranslationSize) | ||||||
|  |         return 0; | ||||||
|  |     return ConnectionTranslation[conn]; | ||||||
|  | } | ||||||
| #else | #else | ||||||
| extern int GetConnectionTranslation(int conn); | extern int GetConnectionTranslation(int conn); | ||||||
| extern void SetConnectionTranslation(int conn, int client); | extern void SetConnectionTranslation(int conn, int client); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue