int netlib_option(net_handle_t handle, int opt, void* optval) { CBaseSocket* pSocket = FindBaseSocket(handle); if (!pSocket) return NETLIB_ERROR; if ((opt >= NETLIB_OPT_GET_REMOTE_IP) && !optval) return NETLIB_ERROR; switch (opt) { case NETLIB_OPT_SET_CALLBACK: pSocket->SetCallback((callback_t)optval); break; case NETLIB_OPT_SET_CALLBACK_DATA: pSocket->SetCallbackData(optval); break; case NETLIB_OPT_GET_REMOTE_IP: *(string*)optval = pSocket->GetRemoteIP(); break; case NETLIB_OPT_GET_REMOTE_PORT: *(uint16_t*)optval = pSocket->GetRemotePort(); break; case NETLIB_OPT_GET_LOCAL_IP: *(string*)optval = pSocket->GetLocalIP(); break; case NETLIB_OPT_GET_LOCAL_PORT: *(uint16_t*)optval = pSocket->GetLocalPort(); } pSocket->ReleaseRef(); return NETLIB_OK; }
bool netlib_shutdown(net_handle_t handle) { CBaseSocket* pSocket = FindBaseSocket(handle); if (!pSocket) return false; return pSocket->Shutdown(2); }
int netlib_close(net_handle_t handle) { CBaseSocket* pSocket = FindBaseSocket(handle); if (!pSocket) return NETLIB_ERROR; int ret = pSocket->Close(); pSocket->ReleaseRef(); return ret; }
int netlib_recv(net_handle_t handle, void* buf, int len) { CBaseSocket* pSocket = FindBaseSocket(handle); if (!pSocket) return NETLIB_ERROR; int ret = pSocket->Recv(buf, len); pSocket->ReleaseRef(); return ret; }
int netlib_send( net_handle_t handle, void *buf, int len) { CBaseSocket *pSocket = FindBaseSocket(handle); if( NULL == pSocket) { return NETLIB_ERROR; } int ret = pSocket->Send(buf, len); pSocket->ReleaseRef(); return ret; }
int netlib_close(net_handle_t handle) { CBaseSocket* pSocket = FindBaseSocket(handle); if (!pSocket) { LOG__(APP, _T("can not find base socket,handle:%d"),handle); return NETLIB_ERROR; } int ret = pSocket->Close(); pSocket->ReleaseRef(); return ret; }
void CEventDispatch::StartDispatch(uint32_t wait_timeout) { struct epoll_event events[1024]; int nfds = 0; if(running) return; running = true; while (running){ nfds = epoll_wait(m_epfd, events, 1024, wait_timeout); for (int i = 0; i < nfds; i++){ int ev_fd = events[i].data.fd; CBaseSocket* pSocket = FindBaseSocket(ev_fd); if (!pSocket) continue; #ifdef EPOLLRDHUP if (events[i].events & EPOLLRDHUP){ Logger.Log(INFO, "On Peer Close, socket=%d", ev_fd); pSocket->OnClose(); } #endif // Commit End if (events[i].events & EPOLLIN){ Logger.Log(INFO, "OnRead, socket=%d\n", ev_fd); pSocket->OnRead(); } if (events[i].events & EPOLLOUT){ Logger.Log(INFO, "OnWrite, socket=%d\n", ev_fd); pSocket->OnWrite(); } if (events[i].events & (EPOLLPRI | EPOLLERR | EPOLLHUP)){ Logger.Log(INFO, "OnClose, socket=%d\n", ev_fd); pSocket->OnClose(); } pSocket->ReleaseRef(); } _CheckTimer(); _CheckLoop(); } }
int netlib_option( net_handle_t handel, int opt, void *optval) { CBaseSocket *pSocket = FindBaseSocket(handel); if( NULL == pSocket ) { return NETLIB_ERROR; } if((opt >= NETLIB_OPT_GET_REMOTE_IP) && !optval ) { return NETLIB_ERROR; } switch (opt) { case NETLIB_OPT_SET_CALLBACK: pSocket->SetCallback((callback_t)optval); break; case NETLIB_OPT_SET_CALLBACK_DATA: pSocket->SetCallbackData(optval); break; case NETLIB_OPT_GET_REMOTE_IP: *(string*)optval = pSocket->GetRemoteIP(); break; case NETLIB_OPT_GET_REMOTE_PORT: *(string*)optval = pSocket->GetRemotePort(); break; case NETLIB_OPT_GET_LOCAL_IP: *(string*)optval = pSocket->GetLocalIP(); break; case NETLIB_OPT_GET_LOCAL_PORT: *(string*)optval = pSocket->GetLocalPort(); break; case NETLIB_OPT_SET_SEND_BUF_SIZE: pSocket->SetSendBufSize(*(uint32_t*)optval); break; case NETLIB_OPT_SET_RECV_BUF_SIZE: pSocket->SetRecvBufSize(*(uint32_t*)optval); break; } pSocket->ReleaseRef(); return NETLIB_OK; }
void CEventDispatch::StartDispatch(uint32_t wait_timeout) { struct epoll_event events[1024]; int nfds = 0; while (running) { nfds = epoll_wait(m_epfd, events, 1024, wait_timeout); for (int i = 0; i < nfds; i++) { int ev_fd = events[i].data.fd; CBaseSocket* pSocket = FindBaseSocket(ev_fd); if (!pSocket) continue; if (events[i].events & EPOLLIN) { //LOG__(NET, "OnRead, socket=%d\n", ev_fd); pSocket->OnRead(); } if (events[i].events & EPOLLOUT) { //LOG__(NET, "OnWrite, socket=%d\n", ev_fd); pSocket->OnWrite(); } if (events[i].events & (EPOLLPRI | EPOLLERR | EPOLLHUP)) { //LOG__(NET, "OnClose, socket=%d\n", ev_fd); pSocket->OnClose(); } pSocket->ReleaseRef(); } _CheckTimer(); _CheckLoop(); } }
void CEventDispatch::StartDispatch() { struct epoll_event events[1024]; int nfds = 0; while (true) { nfds = epoll_wait(m_epfd, events, 1024, MIN_TIMER_DURATION); for (int i = 0; i < nfds; i++) { int ev_fd = events[i].data.fd; CBaseSocket* pSocket = FindBaseSocket(ev_fd); if (!pSocket) continue; if (events[i].events & EPOLLIN) { //log("OnRead, socket=%d\n", ev_fd); pSocket->OnRead(); } if (events[i].events & EPOLLOUT) { //log("OnWrite, socket=%d\n", ev_fd); pSocket->OnWrite(); } if (events[i].events & (EPOLLPRI | EPOLLERR | EPOLLHUP)) { //log("OnClose, socket=%d\n", ev_fd); pSocket->OnClose(); } pSocket->ReleaseRef(); } _CheckTimer(); } }
void CEventDispatch::StartDispatch(uint32_t wait_timeout) { struct kevent events[1024]; int nfds = 0; struct timespec timeout; timeout.tv_sec = 0; timeout.tv_nsec = wait_timeout * 1000000; while (running) { nfds = kevent(m_kqfd, NULL, 0, events, 1024, &timeout); for (int i = 0; i < nfds; i++) { int ev_fd = events[i].ident; CBaseSocket* pSocket = FindBaseSocket(ev_fd); if (!pSocket) continue; if (events[i].filter == EVFILT_READ) { //LOG__(NET, "OnRead, socket=%d\n", ev_fd); pSocket->OnRead(); } if (events[i].filter == EVFILT_WRITE) { //LOG__(NET, "OnWrite, socket=%d\n", ev_fd); pSocket->OnWrite(); } pSocket->ReleaseRef(); } _CheckTimer(); _CheckLoop(); } }
void CEventDispatch::StartDispatch() { struct kevent events[1024]; int nfds = 0; struct timespec timeout; timeout.tv_sec = 0; timeout.tv_nsec = MIN_TIMER_DURATION * 1000000; while (true) { nfds = kevent(m_kqfd, NULL, 0, events, 1024, &timeout); for (int i = 0; i < nfds; i++) { int ev_fd = events[i].ident; CBaseSocket* pSocket = FindBaseSocket(ev_fd); if (!pSocket) continue; if (events[i].filter == EVFILT_READ) { //log("OnRead, socket=%d\n", ev_fd); pSocket->OnRead(); } if (events[i].filter == EVFILT_WRITE) { //log("OnWrite, socket=%d\n", ev_fd); pSocket->OnWrite(); } pSocket->ReleaseRef(); } _CheckTimer(); } }
void CEventDispatch::StartDispatch(uint32_t wait_timeout) { fd_set read_set, write_set, excep_set; timeval timeout; timeout.tv_sec = 1; //wait_timeout 1 second timeout.tv_usec = 0; while (running) { //_CheckTimer(); //_CheckLoop(); if (!m_read_set.fd_count && !m_write_set.fd_count && !m_excep_set.fd_count) { Sleep(MIN_TIMER_DURATION); continue; } m_lock.lock(); FD_ZERO(&read_set); FD_ZERO(&write_set); FD_ZERO(&excep_set); memcpy(&read_set, &m_read_set, sizeof(fd_set)); memcpy(&write_set, &m_write_set, sizeof(fd_set)); memcpy(&excep_set, &m_excep_set, sizeof(fd_set)); m_lock.unlock(); if (!running) break; //for (int i = 0; i < read_set.fd_count; i++) { // LOG__(NET, "read fd: %d\n", read_set.fd_array[i]); //} int nfds = select(0, &read_set, &write_set, &excep_set, &timeout); if (nfds == SOCKET_ERROR) { //LOG__(NET, "select failed, error code: %d\n", GetLastError()); Sleep(MIN_TIMER_DURATION); continue; // select again } if (nfds == 0) { continue; } for (u_int i = 0; i < read_set.fd_count; i++) { //LOG__(NET, "select return read count=%d\n", read_set.fd_count); SOCKET fd = read_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnRead(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < write_set.fd_count; i++) { //LOG__(NET, "select return write count=%d\n", write_set.fd_count); SOCKET fd = write_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnWrite(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < excep_set.fd_count; i++) { LOG__(NET, _T("select return exception count=%d"), excep_set.fd_count); SOCKET fd = excep_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnClose(); pSocket->ReleaseRef(); } } } }
void CEventDispatch::StartDispatch() { fd_set read_set, write_set, excep_set; timeval timeout; timeout.tv_sec = 0; timeout.tv_usec = MIN_TIMER_DURATION * 1000; // 10 millisecond while (true) { _CheckTimer(); if (!m_read_set.fd_count && !m_write_set.fd_count && !m_excep_set.fd_count) { Sleep(MIN_TIMER_DURATION); continue; } m_lock.Lock(); memcpy(&read_set, &m_read_set, sizeof(fd_set)); memcpy(&write_set, &m_write_set, sizeof(fd_set)); memcpy(&excep_set, &m_excep_set, sizeof(fd_set)); m_lock.Unlock(); int nfds = select(0, &read_set, &write_set, &excep_set, &timeout); if (nfds == SOCKET_ERROR) { log("select failed, error code: %d\n", GetLastError()); Sleep(MIN_TIMER_DURATION); continue; // select again } if (nfds == 0) { continue; } for (u_int i = 0; i < read_set.fd_count; i++) { //log("select return read count=%d\n", read_set.fd_count); SOCKET fd = read_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnRead(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < write_set.fd_count; i++) { //log("select return write count=%d\n", write_set.fd_count); SOCKET fd = write_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnWrite(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < excep_set.fd_count; i++) { //log("select return exception count=%d\n", excep_set.fd_count); SOCKET fd = excep_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket) { pSocket->OnClose(); pSocket->ReleaseRef(); } } } }
void CEventDispatch::StartDispatch(uint32_t wait_timeout) { fd_set read_set, write_set, excep_set; timeval timeout; timeout.tv_sec = 0; timeout.tv_usec = wait_timeout * 1000; // 10 millisecond if(running) return; running = true; while (running){ _CheckTimer(); _CheckLoop(); if (!m_read_set.fd_count && !m_write_set.fd_count && !m_excep_set.fd_count){ Sleep(MIN_TIMER_DURATION); continue; } m_lock.lock(); memcpy(&read_set, &m_read_set, sizeof(fd_set)); memcpy(&write_set, &m_write_set, sizeof(fd_set)); memcpy(&excep_set, &m_excep_set, sizeof(fd_set)); m_lock.unlock(); int nfds = select(0, &read_set, &write_set, &excep_set, &timeout); if (nfds == SOCKET_ERROR){ Logger.Log(ERROR, "select failed, error code: %d", GetLastError()); Sleep(MIN_TIMER_DURATION); continue; // select again } if (nfds == 0){ continue; } for (u_int i = 0; i < read_set.fd_count; i++){ SOCKET fd = read_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket){ pSocket->OnRead(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < write_set.fd_count; i++){ SOCKET fd = write_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket){ pSocket->OnWrite(); pSocket->ReleaseRef(); } } for (u_int i = 0; i < excep_set.fd_count; i++){ SOCKET fd = excep_set.fd_array[i]; CBaseSocket* pSocket = FindBaseSocket((net_handle_t)fd); if (pSocket){ pSocket->OnClose(); pSocket->ReleaseRef(); } } } }