-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathbfd.h
executable file
·139 lines (124 loc) · 4.15 KB
/
bfd.h
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
/**************************************************************
* Copyright (c) 2010-2013, Dynamic Network Services, Inc.
* Jake Montgomery ([email protected]) & Tom Daly ([email protected])
* Distributed under the FreeBSD License - see LICENSE
***************************************************************/
/**
Basic headers for the BFD protocol.
This is based on draft-ietf-bfd-base-10.txt (Jan 5th 2010)
*/
#pragma once
// bfd constants are in a special namespace for clarity
namespace bfd
{
const uint16_t BasePacketSize = 24; // without the auth data.
const uint16_t MaxAuthDataSize = 26; // Keyed SHA1 is the biggest at 26 bytes?
const uint16_t AuthHeaderSize = 2; // just the "fixed" info.
const uint16_t MaxPacketSize = (BasePacketSize + MaxAuthDataSize + AuthHeaderSize);
const uint16_t ListenPort = 3784;
const uint8_t TTLValue = 255;
const uint16_t MinSourcePort = 49142U; // Per draft-ietf-bfd-v4v6-1hop-11.txt
const uint16_t MaxSourcePort = 65535U; // Per draft-ietf-bfd-v4v6-1hop-11.txt
const uint8_t Version = 1; // There has not yet been any official release
const uint32_t BaseMinTxInterval = 1000000L; // The base "slow" Tx interval.
// State codes
namespace State
{
enum Value
{
AdminDown = 0,
Down = 1,
Init = 2,
Up = 3,
};
}
const char* StateName(State::Value state);
// Diagnostic codes
namespace Diag
{
enum Value
{
None = 0,
ControlDetectExpired = 1,
EchoFailed = 2,
NeighborSessionDown = 3,
ForwardingReset = 4,
PathDown = 5,
ConcatPathDown = 6,
AdminDown = 7,
ReverseConcatPathDown = 8,
MaxDiagnostic = 31
};
}
const char* DiagString(Diag::Value diag);
const char* DiagShortString(Diag::Value diag);
// Authentication types
namespace AuthType
{
enum Value
{
None = 0,
Password = 1,
MD5 = 2,
MeticulousMD5 = 3,
SHA1 = 4,
MeticulousSHA1 = 5,
};
}
} // namespace
/**
* The actual bfd packet structure.
*/
#pragma pack(push, 1)
struct BfdPacketHeader
{
uint8_t versAndDiag; // version and diagnostic packed into 1 byte
uint8_t flags;
uint8_t detectMult;
uint8_t length; // Total packet length
uint32_t myDisc; // My Discriminator
uint32_t yourDisc; // Your Discriminator
uint32_t txDesiredMinInt;
uint32_t rxRequiredMinInt;
uint32_t rxRequiredMinEchoInt;
//manipulate bit fields
inline uint8_t GetVersion() const { return ((versAndDiag & 0xE0) >> 5);}
inline void SetVersion(uint8_t ver) { versAndDiag = ((ver & 0x07) << 5) | (versAndDiag & 0x1F);}
inline bfd::Diag::Value GetDiag() const { return bfd::Diag::Value(versAndDiag & 0x1F);}
inline void SetDiag(bfd::Diag::Value diag) { versAndDiag = ((uint8_t)diag & 0x1F) | (versAndDiag & 0xE0);}
inline bfd::State::Value GetState() const { return bfd::State::Value((flags >> 6) & 0x03);}
inline void SetState(bfd::State::Value state) { flags = (((uint8_t)state & 0x03) << 6) | (flags & 0x3F);}
inline bool GetPoll() const { return (flags & 0x20);}
inline void SetPoll(bool val) { flags = val ? flags | 0x20 : flags & ~0x20;}
inline bool GetFinal() const { return (flags & 0x10);}
inline void SetFinal(bool val) { flags = val ? flags | 0x10 : flags & ~0x10;}
inline bool GetControlPlaneIndependent() const { return (flags & 0x08);}
inline void SetControlPlaneIndependent(bool val) { flags = val ? flags | 0x08 : flags & ~0x08;}
inline bool GetAuth() const { return (flags & 0x04);}
inline void SetAuth(bool val) { flags = val ? flags | 0x04 : flags & ~0x04;}
inline bool GetDemand() const { return (flags & 0x02);}
inline void SetDemand(bool val) { flags = val ? flags | 0x02 : flags & ~0x02;}
inline bool GetMultipoint() const { return (flags & 0x01);}
inline void SetMultipoint(bool val) { flags = val ? flags | 0x01 : flags & ~0x01;}
};
#pragma pack(pop)
/**
* Optional Authentication header.
*/
#pragma pack(push, 1)
struct BFDAuthData
{
uint8_t type;
uint8_t len;
uint8_t data[bfd::MaxAuthDataSize]; // enough room for the largest.
inline bfd::AuthType::Value GetAuthType() const { return bfd::AuthType::Value(type);}
inline void SetAuthType(bfd::AuthType::Value val) { type = (uint8_t)val;}
};
#pragma pack(pop)
#pragma pack(push, 1)
struct BfdPacket
{
BfdPacketHeader header;
BFDAuthData auth;
};
#pragma pack(pop)