blob: 40706cd7eb6282673d72f96ba490bb6100e89ef9 (
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 <gpxe/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 */
|