summaryrefslogtreecommitdiffstats
path: root/src/include/background.h
blob: 24cb3201f6cecb5515ceab896b7eb456a2c53164 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#ifndef BACKGROUND_H
#define BACKGROUND_H

/** @file
 *
 * Background protocols
 *
 * Some protocols (e.g. ARP, IGMP) operate in the background; the
 * upper layers are not aware of their operation.  When an ARP query
 * for the local station's IP address arrives, Etherboot must reply to
 * it regardless of what other operations are currently in progress.
 *
 * Background protocols are called in two circumstances: when
 * Etherboot is about to poll for a packet, and when Etherboot has
 * received a packet that the upper layer (whatever that may currently
 * be) isn't interested in.
 *
 */

#include "tables.h"
#include "ip.h"

/** A background protocol */
struct background {
	/** Send method
	 *
	 * This method will be called whenever Etherboot is about to
	 * poll for a packet.  The background protocol should use this
	 * method to send out any periodic transmissions that it may
	 * require.
	 */
	void ( *send ) ( unsigned long timestamp );
	/** Process method
	 *
	 * This method will be called whenever Etherboot has received
	 * a packet and doesn't know what to do with it.
	 */
	void ( *process ) ( unsigned long timestamp, unsigned short ptype,
			    struct iphdr *ip );
};

/** A member of the background protocols table */
#define __background __table ( background, 01 )

/* Functions in background.c */

extern void background_send ( unsigned long timestamp );

extern void background_process ( unsigned long timestamp, unsigned short ptype,
				 struct iphdr *ip );

#endif /* BACKGROUND_H */