1 --- net-snmp-5.4.2.1/agent/mibgroup/ucd-snmp/loadave.c~ 2009-12-21 21:00:10.094254079 +0200
2 +++ net-snmp-5.4.2.1/agent/mibgroup/ucd-snmp/loadave.c 2009-12-21 22:02:45.398903148 +0200
5 {LOADAVE, ASN_OCTET_STR, RONLY, var_extensible_loadave, 1,
7 - {LOADMAXVAL, ASN_OCTET_STR, RONLY, var_extensible_loadave, 1,
8 + {LOADMAXVAL, ASN_OCTET_STR, RWRITE, var_extensible_loadave, 1,
10 {LOADAVEINT, ASN_INTEGER, RONLY, var_extensible_loadave, 1,
17 +write_laConfig(int action,
19 + u_char var_val_type,
21 + u_char * statP, oid * name, size_t name_len)
23 + if (var_val_type != ASN_OCTET_STR) {
24 + DEBUGMSGTL(("ucd-snmp/loadave",
25 + "write to laConfig not ASN_OCTET_STR\n"));
26 + return SNMP_ERR_WRONGTYPE;
28 + /* allow max value of 65536.00 */
29 + if (var_val_len > 8) {
30 + DEBUGMSGTL(("ucd-snmp/loadave",
31 + "write to laConfig: bad length\n"));
32 + return SNMP_ERR_WRONGLENGTH;
34 + if (action == COMMIT) {
35 + if (var_val_len != 0) {
37 + if (sscanf(var_val, "%7lf", &val) == 1) {
38 + int idx = name[name_len - 1] - 1;
41 + DEBUGMSGTL(("ucd-snmp/loadave",
42 + "write to laConfig: invalid value\n"));
43 + return SNMP_ERR_WRONGVALUE;
47 + return SNMP_ERR_NOERROR;
51 var_extensible_loadave(struct variable * vp,
55 long_ret = name[*length - 1];
56 return ((u_char *) (&long_ret));
58 + /* setup write method, but don't return yet */
59 + *write_method = write_laConfig;
62 sprintf(errmsg, "Load-%d", ((name[*length - 1] == 1) ? 1 :
63 ((name[*length - 1] == 2) ? 5 : 15)));