]>
git.proxmox.com Git - mirror_frr.git/blob - lib/snmp.c
2 * Copyright (C) 1999 Kunihiro Ishiguro <kunihiro@zebra.org>
4 * This file is part of GNU Zebra.
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; see the file COPYING; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23 #include <net-snmp/net-snmp-config.h>
24 #include <net-snmp/net-snmp-includes.h>
28 #define min(A,B) ((A) < (B) ? (A) : (B))
30 int oid_compare(const oid
*o1
, int o1_len
, const oid
*o2
, int o2_len
)
34 for (i
= 0; i
< min(o1_len
, o2_len
); i
++) {
37 else if (o1
[i
] > o2
[i
])
48 void *oid_copy(void *dest
, const void *src
, size_t size
)
50 return memcpy(dest
, src
, size
* sizeof(oid
));
53 void oid2in_addr(oid oid
[], int len
, struct in_addr
*addr
)
61 pnt
= (uint8_t *)addr
;
63 for (i
= 0; i
< len
; i
++)
67 void oid2in6_addr(oid oid
[], struct in6_addr
*addr
)
72 pnt
= (uint8_t *)addr
;
74 for (i
= 0; i
< sizeof(struct in6_addr
); i
++)
78 void oid2int(oid oid
[], int *dest
)
84 pnt
= (uint8_t *)&network_dest
;
86 for (i
= 0; i
< sizeof(int); i
++)
88 *dest
= ntohl(network_dest
);
91 void oid_copy_in_addr(oid oid
[], const struct in_addr
*addr
)
95 int len
= sizeof(struct in_addr
);
97 pnt
= (uint8_t *)addr
;
99 for (i
= 0; i
< len
; i
++)
104 void oid_copy_in6_addr(oid oid
[], const struct in6_addr
*addr
)
108 int len
= sizeof(struct in6_addr
);
110 pnt
= (uint8_t *)addr
;
112 for (i
= 0; i
< len
; i
++)
116 void oid_copy_int(oid oid
[], int *val
)
122 network_val
= htonl(*val
);
123 pnt
= (uint8_t *)&network_val
;
125 for (i
= 0; i
< sizeof(int); i
++)
129 void oid2string(oid oid
[], int len
, char *string
)
137 pnt
= (uint8_t *)string
;
139 for (i
= 0; i
< len
; i
++)
140 *pnt
++ = (uint8_t)oid
[i
];
143 void oid_copy_str(oid oid
[], const char *string
, int len
)
151 pnt
= (uint8_t *)string
;
153 for (i
= 0; i
< len
; i
++)
157 int smux_header_generic(struct variable
*v
, oid
*name
, size_t *length
,
158 int exact
, size_t *var_len
, WriteMethod
**write_method
)
160 oid fulloid
[MAX_OID_LEN
];
163 oid_copy(fulloid
, v
->name
, v
->namelen
);
164 fulloid
[v
->namelen
] = 0;
165 /* Check against full instance. */
166 ret
= oid_compare(name
, *length
, fulloid
, v
->namelen
+ 1);
168 /* Check single instance. */
169 if ((exact
&& (ret
!= 0)) || (!exact
&& (ret
>= 0)))
172 /* In case of getnext, fill in full instance. */
173 memcpy(name
, fulloid
, (v
->namelen
+ 1) * sizeof(oid
));
174 *length
= v
->namelen
+ 1;
177 *var_len
= sizeof(long); /* default to 'long' results */
179 return MATCH_SUCCEEDED
;
182 int smux_header_table(struct variable
*v
, oid
*name
, size_t *length
, int exact
,
183 size_t *var_len
, WriteMethod
**write_method
)
185 /* If the requested OID name is less than OID prefix we
186 handle, adjust it to our prefix. */
187 if ((oid_compare(name
, *length
, v
->name
, v
->namelen
)) < 0) {
190 oid_copy(name
, v
->name
, v
->namelen
);
191 *length
= v
->namelen
;
195 *var_len
= sizeof(long);
197 return MATCH_SUCCEEDED
;