diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2004-04-17 18:18:26 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2004-04-17 18:18:26 +0000 |
commit | e81bad456aa55af8b0cb31d2ffeb0672ff0c6bbf (patch) | |
tree | 2330a8e8d362ae33a4a83d92be789c01a9dabd61 /src | |
parent | 3345b6c0dc26bf5f5ab848a22b9b5f2887e51574 (diff) |
Added calls to sched_yield() to cut down processor usage - won't work in *bsd
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@635 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src')
-rw-r--r-- | src/dynamic.cpp | 12 | ||||
-rw-r--r-- | src/inspircd.cpp | 12 | ||||
-rw-r--r-- | src/modules.cpp | 2 |
3 files changed, 15 insertions, 11 deletions
diff --git a/src/dynamic.cpp b/src/dynamic.cpp index 4c822e4ca..d18854dc6 100644 --- a/src/dynamic.cpp +++ b/src/dynamic.cpp @@ -4,7 +4,7 @@ -DLLManager::DLLManager( const char *fname ) +DLLManager::DLLManager(const char *fname) { // Try to open the library now and get any error message. @@ -20,10 +20,7 @@ DLLManager::~DLLManager() } -bool DLLManager::GetSymbol( - void **v, - const char *sym_name - ) +bool DLLManager::GetSymbol(void **v, const char *sym_name) { // try extract a symbol from the library // get any error message is there is any @@ -45,10 +42,7 @@ bool DLLManager::GetSymbol( } -DLLFactoryBase::DLLFactoryBase( - const char *fname, - const char *factory - ) : DLLManager(fname) +DLLFactoryBase::DLLFactoryBase(const char *fname, const char *factory) : DLLManager(fname) { // try get the factory function if there is no error yet diff --git a/src/inspircd.cpp b/src/inspircd.cpp index 4f323c2cb..31200017d 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -41,6 +41,8 @@ using namespace std; #include <errno.h> #include <deque> #include <errno.h> +#include <unistd.h> +#include <sched.h> #include "connection.h" #include "users.h" #include "servers.h" @@ -5842,7 +5844,7 @@ void process_command(userrec *user, char* cmd) { if (((command[x] < '0') || (command[x]> '9')) && (command[x] != '-')) { - if (strchr("@!\"$%^&*(){}[]_-=+;:'#~,.<>/?\\|`",command[x])) + if (!strchr("@!\"$%^&*(){}[]_-=+;:'#~,.<>/?\\|`",command[x])) { kill_link(user,"Protocol violation (3)"); return; @@ -7277,6 +7279,9 @@ int InspIRCd(void) /* main loop, this never returns */ for (;;) { +#ifdef _POSIX_PRIORITY_SCHEDULING + sched_yield(); +#endif fd_set sfd; timeval tval; @@ -7434,6 +7439,11 @@ int InspIRCd(void) //if (selectResult2 > 0) for (user_hash::iterator count2a = xcount; count2a != endingiter; count2a++) { + +#ifdef _POSIX_PRIORITY_SCHEDULING + sched_yield(); +#endif + result = EAGAIN; if ((count2a->second->fd != -1) && (FD_ISSET (count2a->second->fd, &sfd))) { diff --git a/src/modules.cpp b/src/modules.cpp index 472c6ca9e..cfb7b3092 100644 --- a/src/modules.cpp +++ b/src/modules.cpp @@ -15,7 +15,7 @@ // class type for holding an extended mode character - internal to core -class ExtMode +class ExtMode : public classbase { public: char modechar; |