blob: db7ceb6ce8873d90ba92e79b7053f361addb852a [file] [log] [blame]
/** @file
A brief file description
@section license License
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
/****************************************************************************
NetAccept.h
NetAccept is a generalized facility which allows
Connections of different classes to be accepted either
from a blockable thread or by adaptive polling.
It is used by the NetProcessor and the ClusterProcessor
and should be considered PRIVATE to processor implementations.
****************************************************************************/
#pragma once
#include <vector>
#include "tscore/ink_platform.h"
#include "P_Connection.h"
struct NetAccept;
class Event;
class SSLNextProtocolAccept;
//
// Default accept function
// Accepts as many connections as possible, returning the number accepted
// or -1 to stop accepting.
//
typedef int(AcceptFunction)(NetAccept *na, void *e, bool blockable);
typedef AcceptFunction *AcceptFunctionPtr;
AcceptFunction net_accept;
class UnixNetVConnection;
// TODO fix race between cancel accept and call back
struct NetAcceptAction : public Action, public RefCountObj {
Server *server;
void
cancel(Continuation *cont = nullptr) override
{
Action::cancel(cont);
server->close();
}
Continuation *
operator=(Continuation *acont)
{
return Action::operator=(acont);
}
~NetAcceptAction() override { Debug("net_accept", "NetAcceptAction dying"); }
};
//
// NetAccept
// Handles accepting connections.
//
struct NetAccept : public Continuation {
ink_hrtime period = 0;
Server server;
AcceptFunctionPtr accept_fn = nullptr;
int ifd = NO_FD;
int id = -1;
Ptr<NetAcceptAction> action_;
SSLNextProtocolAccept *snpa = nullptr;
EventIO ep;
HttpProxyPort *proxyPort = nullptr;
NetProcessor::AcceptOptions opt;
virtual NetProcessor *getNetProcessor() const;
virtual void init_accept(EThread *t = nullptr);
void init_accept_loop();
void init_accept_per_thread();
virtual void stop_accept();
virtual NetAccept *clone() const;
// 0 == success
int do_listen(bool non_blocking);
int do_blocking_accept(EThread *t);
virtual int acceptEvent(int event, void *e);
virtual int acceptFastEvent(int event, void *e);
virtual int accept_per_thread(int event, void *e);
int acceptLoopEvent(int event, Event *e);
void cancel();
explicit NetAccept(const NetProcessor::AcceptOptions &);
~NetAccept() override { action_ = nullptr; }
};
extern Ptr<ProxyMutex> naVecMutex;
extern std::vector<NetAccept *> naVec;