2006-08-08 13:07:07 +00:00
|
|
|
/*
|
2007-04-04 09:41:04 +00:00
|
|
|
* Copyright 2006-2007, Haiku, Inc. All Rights Reserved.
|
2006-08-08 13:07:07 +00:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
|
|
|
#ifndef NET_STACK_H
|
|
|
|
#define NET_STACK_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <lock.h>
|
|
|
|
#include <util/list.h>
|
|
|
|
|
|
|
|
#include <module.h>
|
|
|
|
|
|
|
|
|
|
|
|
#define NET_STACK_MODULE_NAME "network/stack/v1"
|
|
|
|
|
2007-05-03 21:18:21 +00:00
|
|
|
|
|
|
|
struct net_address_module_info;
|
|
|
|
struct net_protocol_module_info;
|
|
|
|
|
|
|
|
struct net_buffer;
|
|
|
|
struct net_device;
|
|
|
|
struct net_domain;
|
|
|
|
struct net_socket;
|
|
|
|
struct net_timer;
|
|
|
|
|
2006-08-08 13:07:07 +00:00
|
|
|
struct net_fifo {
|
|
|
|
benaphore lock;
|
|
|
|
sem_id notify;
|
|
|
|
int32 waiting;
|
|
|
|
|
|
|
|
size_t max_bytes;
|
|
|
|
size_t current_bytes;
|
|
|
|
|
|
|
|
struct list buffers;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef void (*net_timer_func)(struct net_timer *timer, void *data);
|
|
|
|
|
|
|
|
struct net_timer {
|
|
|
|
struct list_link link;
|
|
|
|
net_timer_func hook;
|
|
|
|
void *data;
|
|
|
|
bigtime_t due;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef int32 (*net_deframe_func)(struct net_device *device, struct net_buffer *buffer);
|
2007-04-20 04:40:53 +00:00
|
|
|
typedef status_t (*net_receive_func)(void *cookie, struct net_device *,
|
|
|
|
struct net_buffer *buffer);
|
2006-08-08 13:07:07 +00:00
|
|
|
|
2007-04-08 09:15:52 +00:00
|
|
|
enum {
|
|
|
|
B_DEVICE_GOING_UP = 1,
|
|
|
|
B_DEVICE_GOING_DOWN,
|
|
|
|
B_DEVICE_BEING_REMOVED,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct net_device_monitor {
|
|
|
|
struct list_link link;
|
|
|
|
void *cookie;
|
|
|
|
|
|
|
|
status_t (*receive)(struct net_device_monitor *monitor,
|
|
|
|
struct net_buffer *buffer);
|
|
|
|
void (*event)(struct net_device_monitor *monitor, int32 event);
|
|
|
|
};
|
|
|
|
|
2006-08-08 13:07:07 +00:00
|
|
|
struct net_stack_module_info {
|
|
|
|
module_info info;
|
|
|
|
|
|
|
|
status_t (*register_domain)(int family, const char *name,
|
|
|
|
struct net_protocol_module_info *module,
|
|
|
|
struct net_address_module_info *addressModule,
|
|
|
|
struct net_domain **_domain);
|
|
|
|
status_t (*unregister_domain)(struct net_domain *domain);
|
|
|
|
struct net_domain *(*get_domain)(int family);
|
|
|
|
|
|
|
|
status_t (*register_domain_protocols)(int family, int type, int protocol, ...);
|
|
|
|
status_t (*register_domain_datalink_protocols)(int family, int type, ...);
|
|
|
|
status_t (*register_domain_receiving_protocol)(int family, int type,
|
|
|
|
const char *moduleName);
|
|
|
|
|
2007-10-21 20:10:43 +00:00
|
|
|
status_t (*get_domain_receiving_protocol)(struct net_domain *domain,
|
|
|
|
uint32 type, struct net_protocol_module_info **_module);
|
|
|
|
status_t (*put_domain_receiving_protocol)(struct net_domain *domain,
|
|
|
|
uint32 type);
|
2006-08-08 13:07:07 +00:00
|
|
|
|
|
|
|
// devices
|
|
|
|
status_t (*register_device_deframer)(struct net_device *device,
|
|
|
|
net_deframe_func deframeFunc);
|
|
|
|
status_t (*unregister_device_deframer)(struct net_device *device);
|
|
|
|
|
|
|
|
status_t (*register_domain_device_handler)(struct net_device *device,
|
|
|
|
int32 type, struct net_domain *domain);
|
|
|
|
status_t (*register_device_handler)(struct net_device *device, int32 type,
|
|
|
|
net_receive_func receiveFunc, void *cookie);
|
|
|
|
status_t (*unregister_device_handler)(struct net_device *device, int32 type);
|
|
|
|
|
|
|
|
status_t (*register_device_monitor)(struct net_device *device,
|
2007-10-21 20:10:43 +00:00
|
|
|
struct net_device_monitor *monitor);
|
2006-08-08 13:07:07 +00:00
|
|
|
status_t (*unregister_device_monitor)(struct net_device *device,
|
2007-10-21 20:10:43 +00:00
|
|
|
struct net_device_monitor *monitor);
|
2006-08-08 13:07:07 +00:00
|
|
|
|
2007-04-04 09:41:04 +00:00
|
|
|
status_t (*device_link_changed)(struct net_device *device);
|
2006-08-08 13:07:07 +00:00
|
|
|
status_t (*device_removed)(struct net_device *device);
|
|
|
|
|
2007-05-23 07:56:15 +00:00
|
|
|
status_t (*device_enqueue_buffer)(struct net_device *device,
|
2007-10-21 20:10:43 +00:00
|
|
|
struct net_buffer *buffer);
|
2007-05-23 07:56:15 +00:00
|
|
|
|
2006-08-08 13:07:07 +00:00
|
|
|
// Utility Functions
|
|
|
|
|
2006-10-07 12:32:02 +00:00
|
|
|
// notification
|
2007-10-21 20:10:43 +00:00
|
|
|
status_t (*notify_socket)(struct net_socket *socket, uint8 event,
|
|
|
|
int32 value);
|
2006-10-07 12:32:02 +00:00
|
|
|
|
2006-08-08 13:07:07 +00:00
|
|
|
// checksum
|
|
|
|
uint16 (*checksum)(uint8 *buffer, size_t length);
|
|
|
|
|
|
|
|
// fifo
|
2007-10-21 20:10:43 +00:00
|
|
|
status_t (*init_fifo)(struct net_fifo *fifo, const char *name,
|
|
|
|
size_t maxBytes);
|
2006-08-08 13:07:07 +00:00
|
|
|
void (*uninit_fifo)(struct net_fifo *fifo);
|
2007-10-21 20:10:43 +00:00
|
|
|
status_t (*fifo_enqueue_buffer)(struct net_fifo *fifo,
|
|
|
|
struct net_buffer *buffer);
|
2006-08-08 13:07:07 +00:00
|
|
|
ssize_t (*fifo_dequeue_buffer)(struct net_fifo *fifo, uint32 flags,
|
|
|
|
bigtime_t timeout, struct net_buffer **_buffer);
|
|
|
|
status_t (*clear_fifo)(struct net_fifo *fifo);
|
2007-10-21 20:10:43 +00:00
|
|
|
status_t (*fifo_socket_enqueue_buffer)(struct net_fifo *fifo,
|
|
|
|
struct net_socket *socket, uint8 event,
|
|
|
|
struct net_buffer *buffer);
|
2006-08-08 13:07:07 +00:00
|
|
|
|
|
|
|
// timer
|
|
|
|
void (*init_timer)(struct net_timer *timer, net_timer_func hook, void *data);
|
|
|
|
void (*set_timer)(struct net_timer *timer, bigtime_t delay);
|
2006-11-29 19:09:19 +00:00
|
|
|
bool (*cancel_timer)(struct net_timer *timer);
|
|
|
|
bool (*is_timer_active)(struct net_timer *timer);
|
2006-08-08 13:07:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // NET_STACK_H
|