0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-08 18:11:54 +00:00

SNMP: Remove transmit hook, new macros

This commit is contained in:
Vojtech Vilimek 2023-09-04 13:46:02 +02:00
parent df28d1cbe8
commit 7543da15d8
6 changed files with 59 additions and 67 deletions

View File

@ -49,6 +49,26 @@ static const char * const debug_bgp_states[] UNUSED = {
[BGP_INTERNAL_NO_VALUE] = "BGP_INTERNAL_NO_VALUE", [BGP_INTERNAL_NO_VALUE] = "BGP_INTERNAL_NO_VALUE",
}; };
static inline uint
snmp_bgp_fsm_state(struct bgp_proto *bgp_proto)
{
const struct bgp_conn *bgp_conn = bgp_proto->conn;
const struct bgp_conn *bgp_in = &bgp_proto->incoming_conn;
const struct bgp_conn *bgp_out = &bgp_proto->outgoing_conn;
if (bgp_conn)
return bgp_conn->state;
if (MAX(bgp_in->state, bgp_out->state) == BS_CLOSE &&
MIN(bgp_in->state, bgp_out->state) != BS_CLOSE)
return MIN(bgp_in->state, bgp_out->state);
if (MIN(bgp_in->state, bgp_out->state) == BS_CLOSE)
return BS_IDLE;
return MAX(bgp_in->state, bgp_out->state);
}
void void
snmp_bgp_register(struct snmp_proto *p) snmp_bgp_register(struct snmp_proto *p)
{ {
@ -881,20 +901,9 @@ bgp_fill_dynamic(struct snmp_proto UNUSED *p, struct agentx_varbind *vb,
struct bgp_stats *bgp_stats = &bgp_proto->stats; struct bgp_stats *bgp_stats = &bgp_proto->stats;
const struct bgp_config *bgp_conf = bgp_proto->cf; const struct bgp_config *bgp_conf = bgp_proto->cf;
uint bgp_state; uint bgp_state = snmp_bgp_fsm_state(bgp_proto);
if (bgp_conn) char last_error[2] = SNMP_BGP_LAST_ERROR(bgp_proto);
bgp_state = bgp_conn->state;
else if (MAX(bgp_in->state, bgp_out->state) == BS_CLOSE &&
MIN(bgp_in->state, bgp_out->state) != BS_CLOSE)
bgp_state = MIN(bgp_in->state, bgp_out->state);
else if (MIN(bgp_in->state, bgp_out->state) == BS_CLOSE)
bgp_state = BS_IDLE;
else
bgp_state = MAX(bgp_in->state, bgp_out->state);
char last_error[2] = { bgp_proto->last_error_code & 0x00FF0000 >> 16,
bgp_proto->last_error_code & 0x000000FF };
switch (state) switch (state)
{ {
case BGP_INTERNAL_IDENTIFIER: case BGP_INTERNAL_IDENTIFIER:

View File

@ -90,4 +90,8 @@ enum BGP_INTERNAL_STATES {
BGP_INTERNAL_NO_VALUE = 255, BGP_INTERNAL_NO_VALUE = 255,
} PACKED; } PACKED;
#define SNMP_BGP_LAST_ERROR(bgp_proto) \
{ bgp_proto->last_error_code & 0x00FF0000 >> 16, \
bgp_proto->last_error_code & 0x000000FF };
#endif #endif

View File

@ -267,7 +267,8 @@ snmp_connected(sock *sk)
byte *buf UNUSED = sk->rpos; byte *buf UNUSED = sk->rpos;
sk->rx_hook = snmp_rx; sk->rx_hook = snmp_rx;
sk->tx_hook = snmp_tx; sk->tx_hook = NULL;
//sk->tx_hook = snmp_tx;
snmp_start_subagent(p); snmp_start_subagent(p);

View File

@ -149,6 +149,6 @@ struct snmp_proto {
struct agentx_response *partial_response; struct agentx_response *partial_response;
}; };
void snmp_tx(sock *sk); //void snmp_tx(sock *sk);
#endif #endif

View File

@ -81,10 +81,7 @@ open_pdu(struct snmp_proto *p, struct oid *oid)
{ {
sock *sk = p->sock; sock *sk = p->sock;
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos,
.size = sk->tbuf + sk->tbsize - sk->tpos,
};
byte *buf = c.buffer; byte *buf = c.buffer;
// TODO should be configurable; with check on string length // TODO should be configurable; with check on string length
@ -102,6 +99,7 @@ open_pdu(struct snmp_proto *p, struct oid *oid)
struct agentx_header *h = (struct agentx_header *) c.buffer; struct agentx_header *h = (struct agentx_header *) c.buffer;
ADVANCE(c.buffer, c.size, AGENTX_HEADER_SIZE); ADVANCE(c.buffer, c.size, AGENTX_HEADER_SIZE);
SNMP_BLANK_HEADER(h, AGENTX_OPEN_PDU); SNMP_BLANK_HEADER(h, AGENTX_OPEN_PDU);
c.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER;
STORE_U32(h->session_id, 1); STORE_U32(h->session_id, 1);
STORE_U32(h->transaction_id, 1); STORE_U32(h->transaction_id, 1);
@ -127,22 +125,7 @@ notify_pdu(struct snmp_proto *p, struct oid *oid, void *opaque, uint size, int i
{ {
sock *sk = p->sock; sock *sk = p->sock;
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos,
.size = sk->tbuf + sk->tbsize - sk->tpos,
};
if (c.size < AGENTX_HEADER_SIZE)
{
snmp_manage_tbuf(p, &c);
}
struct agentx_header *h = (struct agentx_header *) c.buffer;
ADVANCE(c.buffer, c.size, AGENTX_HEADER_SIZE);
SNMP_BLANK_HEADER(h, AGENTX_NOTIFY_PDU);
SNMP_SESSION(h, p);
c.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER;
#define UPTIME_SIZE \ #define UPTIME_SIZE \
(6 * sizeof(u32)) /* sizeof( { u32 vb_type, u32 oid_hdr, u32 ids[4] } )*/ (6 * sizeof(u32)) /* sizeof( { u32 vb_type, u32 oid_hdr, u32 ids[4] } )*/
@ -150,7 +133,7 @@ notify_pdu(struct snmp_proto *p, struct oid *oid, void *opaque, uint size, int i
(7 * sizeof(u32)) /* sizeof( { u32 vb_type, u32 oid_hdr, u32 ids[6] } ) */ (7 * sizeof(u32)) /* sizeof( { u32 vb_type, u32 oid_hdr, u32 ids[6] } ) */
uint sz = AGENTX_HEADER_SIZE + TRAP0_HEADER_SIZE + snmp_oid_size(oid) \ uint sz = AGENTX_HEADER_SIZE + TRAP0_HEADER_SIZE + snmp_oid_size(oid) \
+ snmp_varbind_hdr_size_from_oid(oid) + size; + size;
if (include_uptime) if (include_uptime)
sz += UPTIME_SIZE; sz += UPTIME_SIZE;
@ -158,6 +141,12 @@ notify_pdu(struct snmp_proto *p, struct oid *oid, void *opaque, uint size, int i
if (c.size < sz) if (c.size < sz)
snmp_manage_tbuf(p, &c); snmp_manage_tbuf(p, &c);
struct agentx_header *h = (struct agentx_header *) c.buffer;
ADVANCE(c.buffer, c.size, AGENTX_HEADER_SIZE);
SNMP_BLANK_HEADER(h, AGENTX_NOTIFY_PDU);
SNMP_SESSION(h, p);
c.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER;
if (include_uptime) if (include_uptime)
{ {
/* sysUpTime.0 oid */ /* sysUpTime.0 oid */
@ -245,10 +234,7 @@ static void
un_register_pdu(struct snmp_proto *p, struct oid *oid, uint index, uint len, u8 type, u8 is_instance) un_register_pdu(struct snmp_proto *p, struct oid *oid, uint index, uint len, u8 type, u8 is_instance)
{ {
sock *sk = p->sock; sock *sk = p->sock;
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos,
.size = sk->tbuf + sk->tbsize - sk->tpos,
};
byte *buf = c.buffer; byte *buf = c.buffer;
/* conditional +4 for upper-bound (optinal field) */ /* conditional +4 for upper-bound (optinal field) */
@ -269,6 +255,7 @@ un_register_pdu(struct snmp_proto *p, struct oid *oid, uint index, uint len, u8
/* use new transactionID, reset packetID */ /* use new transactionID, reset packetID */
p->packet_id++; p->packet_id++;
SNMP_SESSION(h, p); SNMP_SESSION(h, p);
c.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER;
/* do not override timeout */ /* do not override timeout */
STORE_U32(ur->timeout, 15); STORE_U32(ur->timeout, 15);
@ -317,10 +304,7 @@ static void
close_pdu(struct snmp_proto *p, u8 reason) close_pdu(struct snmp_proto *p, u8 reason)
{ {
sock *sk = p->sock; sock *sk = p->sock;
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos,
.size = sk->tbuf + sk->tbsize - sk->tpos,
};
byte *buf = c.buffer; byte *buf = c.buffer;
snmp_log("close_pdu() size: %u %c %u", c.size, (c.size > AGENTX_HEADER_SIZE + 4) snmp_log("close_pdu() size: %u %c %u", c.size, (c.size > AGENTX_HEADER_SIZE + 4)
@ -338,6 +322,7 @@ close_pdu(struct snmp_proto *p, u8 reason)
SNMP_BLANK_HEADER(h, AGENTX_CLOSE_PDU); SNMP_BLANK_HEADER(h, AGENTX_CLOSE_PDU);
p->packet_id++; p->packet_id++;
SNMP_SESSION(h, p); SNMP_SESSION(h, p);
c.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER;
snmp_put_fbyte(c.buffer, reason); snmp_put_fbyte(c.buffer, reason);
ADVANCE(c.buffer, c.size, 4); ADVANCE(c.buffer, c.size, 4);
@ -665,7 +650,7 @@ do_response(struct snmp_proto *p, byte *buf, uint size UNUSED)
break; break;
case SNMP_STOP: case SNMP_STOP:
snmp_shutdown(); snmp_down(p);
break; break;
default: default:
@ -914,13 +899,9 @@ parse_gets2_pdu(struct snmp_proto *p, byte * const pkt_start, uint size, uint *s
uint pkt_size = LOAD_U32(h->payload, h->flags & AGENTX_NETWORK_BYTE_ORDER); uint pkt_size = LOAD_U32(h->payload, h->flags & AGENTX_NETWORK_BYTE_ORDER);
sock *sk = p->sock; sock *sk = p->sock;
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos, // TODO better handling of endianness
.size = sk->tbuf + sk->tbsize - sk->tpos, c.byte_ord = 0; /* use little-endian */
.byte_ord = h->flags & AGENTX_NETWORK_BYTE_ORDER,
.error = AGENTX_RES_NO_ERROR,
.context = 0,
};
uint clen; /* count of characters in context (without last '\0') */ uint clen; /* count of characters in context (without last '\0') */
char *context; /* newly allocated string of character */ char *context; /* newly allocated string of character */
@ -1305,10 +1286,7 @@ snmp_ping(struct snmp_proto *p)
sock *sk = p->sock; sock *sk = p->sock;
snmp_dump_packet(sk->tpos, AGENTX_HEADER_SIZE + 4); snmp_dump_packet(sk->tpos, AGENTX_HEADER_SIZE + 4);
snmp_log("snmp_ping sk->tpos 0x%p", sk->tpos); snmp_log("snmp_ping sk->tpos 0x%p", sk->tpos);
struct snmp_pdu_context c = { struct snmp_pdu_context c = SNMP_PDU_CONTEXT(sk);
.buffer = sk->tpos,
.size = sk->tbuf + sk->tbsize - sk->tpos,
};
if (c.size < AGENTX_HEADER_SIZE) if (c.size < AGENTX_HEADER_SIZE)
snmp_manage_tbuf(p, &c); snmp_manage_tbuf(p, &c);
@ -1319,6 +1297,7 @@ snmp_ping(struct snmp_proto *p)
SNMP_BLANK_HEADER(h, AGENTX_PING_PDU); SNMP_BLANK_HEADER(h, AGENTX_PING_PDU);
p->packet_id++; p->packet_id++;
SNMP_SESSION(h, p); SNMP_SESSION(h, p);
c.byte_ord = AGENTX_NETWORK_BYTE_ORDER;
snmp_log("sending ping packet ... tpos 0x%p", sk->tpos); snmp_log("sending ping packet ... tpos 0x%p", sk->tpos);
snmp_dump_packet(sk->tpos, AGENTX_HEADER_SIZE + 4); snmp_dump_packet(sk->tpos, AGENTX_HEADER_SIZE + 4);
@ -1612,21 +1591,13 @@ send_remaining_buffers(sock *sk)
} }
#endif #endif
/*
void void
snmp_tx(sock UNUSED *sk) snmp_tx(sock UNUSED *sk)
{ {
snmp_log("snmp_tx"); snmp_log("snmp_tx");
//struct snmp_proto *p = sk->data;
return;
#if 0
if (!p->partial_response)
return;
send_remaining_buffers(sk);
#endif
} }
*/
static struct agentx_response * static struct agentx_response *

View File

@ -125,6 +125,13 @@ enum snmp_search_res {
#define SNMP_VB_DATA(varbind) \ #define SNMP_VB_DATA(varbind) \
(((void *)(varbind)) + snmp_varbind_header_size(varbind)) (((void *)(varbind)) + snmp_varbind_header_size(varbind))
#define SNMP_PDU_CONTEXT(sk) { \
.buffer = sk->tpos, \
.size = sk->tbuf + sk->tbsize - sk->tpos, \
.error = AGENTX_RES_NO_ERROR, \
.context = 0, \
}
struct agentx_header { struct agentx_header {
u8 version; u8 version;
u8 type; u8 type;