2017-04-21 10:43:26 +00:00
# F-Stack API Reference
2018-10-25 15:03:45 +00:00
F-Stack (FF) is a high-performance network framework based on DPDK.
2017-04-21 10:43:26 +00:00
2018-10-25 15:03:45 +00:00
FF API provides the standard Kqueue/Epoll interface, and a micro threading framework (SPP).
2017-04-21 10:43:26 +00:00
2018-10-25 15:03:45 +00:00
In order to facilitate a variety of services to use F-Stack simpler and faster, F-Stack has been integrated with Nginx and Redis。
2017-04-21 10:43:26 +00:00
## FF API
2018-10-25 15:03:45 +00:00
The header file ff_api.h defines the following API, which should be used to replace the system calls when using F-Stack.
2017-04-21 10:43:26 +00:00
### Initialize
#### ff_init
int ff_init(const char *conf, int argc, char * const argv[]);
conf:Profile path
argv: -c < coremask > ,the coremask parameters can cover the coremask in configuration file
2018-10-25 15:03:45 +00:00
Initialize F-Stack, including DPDK/FreeBSD network stack, etc.
2017-04-21 10:43:26 +00:00
#### ff_run
void ff_run(loop_func_t loop, void *arg);
2019-05-29 07:21:17 +00:00
loop is a callback function, the service logic is implemented by the user, and called by each poll of F-Stack .
2017-04-21 10:43:26 +00:00
### Control API
#### ff_fcntl
int ff_fcntl(int fd, int cmd, ...);
fcntl() performs one of the operations described below on the open file descriptor fd. The operation is determined by cmd.
2018-10-25 15:03:45 +00:00
more info see man fcntl.
2017-04-21 10:43:26 +00:00
#### ff_sysctl
int ff_sysctl(const int *name, u_int namelen, void *oldp, size_t *oldlenp,
const void *newp, size_t newlen);
ff_sysctl is used to modify kernel parameters at runtime.
2018-10-25 15:03:45 +00:00
However, it is supported only before F-Stack is started.
2017-04-21 10:43:26 +00:00
#### ff_ioctl
int ff_ioctl(int fd, unsigned long request, ...);
The ioctl() function manipulates the underlying device parameters of special files.
2018-10-25 15:03:45 +00:00
more info see man ioctl.
2017-04-21 10:43:26 +00:00
2024-03-30 05:10:03 +00:00
#### ff_stop_run
void ff_stop_run();
Stop the infinite poll loop started by `ff_run` .
2017-04-21 10:43:26 +00:00
### Network API
#### ff_socket
int ff_socket(int domain, int type, int protocol);
2018-10-25 15:03:45 +00:00
ff_socket creates an endpoint for communication and returns a file descriptor that refers to that endpoint.
more info see man socket.
2017-04-21 10:43:26 +00:00
#### ff_setsockopt & ff_getsockopt
int ff_getsockopt(int s, int level, int optname, void *optval,
socklen_t *optlen);
int ff_setsockopt(int s, int level, int optname, const void *optval,
socklen_t optlen);
2018-10-25 15:03:45 +00:00
getsockopt() and setsockopt() manipulate options for the socket denoted by the file descriptor sockfd.
2017-04-21 10:43:26 +00:00
more info see man getsockopt and man setsockopt.
#### ff_socketpair
int ff_socketpair(int domain, int type, int protocol, int *sv);
2018-10-25 15:03:45 +00:00
The socketpair() call creates an unnamed pair of connected sockets in the given domain in the specified type, and uses the optionally given protocol.
more info see man socketpair.
2017-04-21 10:43:26 +00:00
#### Socket operation function
int ff_listen(int s, int backlog);
int ff_bind(int s, const struct linux_sockaddr *addr, socklen_t addrlen);
int ff_accept(int s, struct linux_sockaddr *addr, socklen_t *addrlen);
int ff_connect(int s, const struct linux_sockaddr *name, socklen_t namelen);
int ff_close(int fd);
int ff_shutdown(int s, int how);
Socket operation function, more info see Linux Programmer's Manual.
#### ff_getpeername
int ff_getpeername(int s, struct linux_sockaddr *name, socklen_t *namelen);
ff_getpeername() returns the address of the peer connected to the socket sockfd, in the buffer pointed to by addr.
more info see man getpeername.
#### ff_getsockname
int ff_getsockname(int s, struct linux_sockaddr *name,
socklen_t *namelen);
ff_getsockname() returns the current address to which the socket sockfd is bound, in the buffer pointed to by addr.
more info see man getsockname.
#### ff\_read & ff\_readv
ssize_t ff_read(int d, void *buf, size_t nbytes);
ssize_t ff_readv(int fd, const struct iovec *iov, int iovcnt);
read() attempts to read up to count bytes from file descriptor fd into the buffer starting at buf.
more info see man read and man readv.
#### ff\_write & ff\_writev
ssize_t ff_write(int fd, const void *buf, size_t nbytes);
ssize_t ff_writev(int fd, const struct iovec *iov, int iovcnt);
write() writes up to count bytes from the buffer pointed buf to the file referred to by the file descriptor fd.
more info see man write and man readv.
#### ff\_send & ff\_sendto & ff\_sendmsg
ssize_t ff_send(int s, const void *buf, size_t len, int flags);
ssize_t ff_sendto(int s, const void *buf, size_t len, int flags, const struct linux_sockaddr *to, socklen_t tolen);
ssize_t ff_sendmsg(int s, const struct msghdr *msg, int flags);
2018-10-25 15:03:45 +00:00
Functions to send a message on a socket.
2017-04-21 10:43:26 +00:00
more info see man send.
#### ff\_recv & ff\_recvfrom & ff\_recvmsg
ssize_t ff_recv(int s, void *buf, size_t len, int flags);
ssize_t ff_recvfrom(int s, void *buf, size_t len, int flags, struct linux_sockaddr *from, socklen_t *fromlen);
ssize_t ff_recvmsg(int s, struct msghdr *msg, int flags);
2018-10-25 15:03:45 +00:00
Functions to receive a message from a socket.
2017-04-21 10:43:26 +00:00
more info see man recv.
#### ff_select
int ff_select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);
select() allow a program to monitor multiple file descriptors, waiting until one or more of the file descriptors become "ready" for some class of I/O operation (e.g., input possible).
more info see man select.
#### ff_poll
int ff_poll(struct pollfd fds[], nfds_t nfds, int timeout);
2018-10-25 15:03:45 +00:00
ff_poll waits for events on a file descriptor.
2017-04-21 10:43:26 +00:00
more info see man poll.
### Kqueue API
#### ff_kqueue
int ff_kqueue(void);
int ff_kevent(int kq, const struct kevent *changelist, int nchanges, struct kevent *eventlist, int nevents, const struct timespec *timeout);
2018-10-25 15:03:45 +00:00
The kqueue() system call provides a generic method of notifying the user when an event occurs or a condition holds, based on the results of small pieces of kernel code termed filters.
2017-04-21 10:43:26 +00:00
more info see man kqueue on FreeBSD System Calls Manual.
### Epoll API
#### ff\_epoll\_create
int ff_epoll_create(int size);
epoll_create() returns a file descriptor referring to the new epoll instance.
more info see man epoll_create.
#### ff\_epoll\_ctl
int ff_epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);
2018-10-25 15:03:45 +00:00
This system call performs control operations on the epoll(7) instance referred by the file descriptor epfd.
2017-04-21 10:43:26 +00:00
more info see man epoll_ctl.
### Micro Thread API `micro_thread/mt_api.h`
2018-10-25 15:03:45 +00:00
In order to develop asynchronous program convenient without complex asynchronous logic processing (reference [SPP's micro thread framework ](https://github.com/Tencent/MSEC/tree/master/spp_rpc )), F-Stack provides a micro thread framework so that synchronous programming can be achieved using asynchronous calls.
2017-04-21 10:43:26 +00:00
#### UDP send/recv interface
int mt_udpsendrcv(struct sockaddr_in* dst, void* pkg, int len, void* rcv_buf, int& buf_size, int timeout);
Use Random socket port to send and recv udp packet.
#### tcp send/recv interface
int mt_tcpsendrcv(struct sockaddr_in* dst, void* pkg, int len, void* rcv_buf, int& buf_size, int timeout, MtFuncTcpMsgLen chek_func);
Use connection pool to send and recv tcp packet, keep-alive default are 10 mintues. The parameter of buf can't use `static` .
2017-05-09 06:29:51 +00:00
enum MT_TCP_CONN_TYPE
2017-04-21 10:43:26 +00:00
{
2017-05-09 06:29:51 +00:00
MT_TCP_SHORT = 1,
MT_TCP_LONG = 2,
MT_TCP_SHORT_SNDONLY = 3,
MT_TCP_LONG_SNDONLY = 4,
MT_TCP_BUTT
2017-04-21 10:43:26 +00:00
};
2017-05-09 06:29:51 +00:00
int mt_tcpsendrcv_ex(struct sockaddr_in* dst, void* pkg, int len, void* rcv_buf, int* buf_size, int timeout, MtFuncTcpMsgLen func, MT_TCP_CONN_TYPE type = MT_TCP_LONG);
2017-04-21 10:43:26 +00:00
2018-10-25 15:03:45 +00:00
TCP send and recv interface, you can choose if the connection is keep-alive or close.The parameter of buf can't use `static` .
2017-04-21 10:43:26 +00:00
2017-05-09 06:30:26 +00:00
int mt_tcpsendrcv_ex(struct sockaddr_in* dst, void* pkg, int len, void*& rcv_buf, int& recv_pkg_size, int timeout, MtFuncTcpMsgChecker check_func, void* msg_ctx=NULL, MT_TCP_CONN_TYPE type = MT_TCP_LONG, bool keep_rcv_buf=false);
2017-04-21 10:43:26 +00:00
Tcp send and recv interface, you can choose if the connection is keep-alive or close.The parameter of buf can't use `static` .
int mt_tcpsendrcv(struct sockaddr_in* dst, void* pkg, int len, void*& rcv_buf, int& recv_pkg_size, int timeout, MtFuncTcpMsgChecker check_func, void* msg_ctx=NULL, bool keep_rcv_buf=false);
Use connection pool to send and recv tcp packet, keep-alive default are 10 mintues. The parameter of buf can't use `static` .
2018-10-25 15:03:45 +00:00
#### Socket API for micro threads
2017-04-21 10:43:26 +00:00
see `micro_thread/mt_api.h` .
2019-06-25 04:38:19 +00:00
### Dispatch API
Packet dispatch callback function, implemented by user.
typedef int (*dispatch_func_t)(void *data, uint16_t *len, uint16_t queue_id, uint16_t nb_queues);
void ff_regist_packet_dispatcher(dispatch_func_t func);
Regist a packet dispath function.
#### param
- data
The data pointer of this packet.
- len
The length of this packet.
- queue_id
Current queue of this packet.
- nb_queues
Number of queues to be dispatched.
#### return
- 0 to (nb_queues - 1)
The queue id that the packet will be dispatched to.
- FF_DISPATCH_ERROR (-1)
Error occurs or packet is handled by user, packet will be freed.
- FF_DISPATCH_RESPONSE (-2)
2019-06-25 11:52:08 +00:00
Packet is handled by user, packet will be responsed.