snmp_mib2_system_patch.diff 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. diff --git a/thirdparty/lwip/src/apps/snmp/snmp_mib2_system.c b/thirdparty/lwip/src/apps/snmp/snmp_mib2_system.c
  2. index 4aa2926..0ff8c76 100755
  3. --- a/thirdparty/lwip/src/apps/snmp/snmp_mib2_system.c
  4. +++ b/thirdparty/lwip/src/apps/snmp/snmp_mib2_system.c
  5. @@ -43,6 +43,10 @@
  6. #include <string.h>
  7. +#ifdef SNMP_SYS_PARAM_FILENAME
  8. +#include SNMP_SYS_PARAM_FILENAME
  9. +#endif
  10. +
  11. #if LWIP_SNMP && SNMP_LWIP_MIB2
  12. #if SNMP_USE_NETCONN
  13. @@ -284,6 +288,7 @@ system_set_test(const struct snmp_scalar_array_node_def *node, u16_t len, void *
  14. snmp_err_t ret = SNMP_ERR_WRONGVALUE;
  15. const u16_t* var_bufsize = NULL;
  16. const u16_t* var_wr_len;
  17. + bool check_flag = true;
  18. LWIP_UNUSED_ARG(value);
  19. @@ -307,13 +312,16 @@ system_set_test(const struct snmp_scalar_array_node_def *node, u16_t len, void *
  20. /* check if value is writable at all */
  21. if (*var_bufsize > 0) {
  22. +#ifdef SNMP_SYS_PARAM_CHECK
  23. + check_flag = SNMP_SYS_PARAM_CHECK(value, len);
  24. +#endif
  25. if (var_wr_len == NULL) {
  26. /* we have to take the terminating 0 into account */
  27. - if (len < *var_bufsize) {
  28. + if (len < *var_bufsize && check_flag) {
  29. ret = SNMP_ERR_NOERROR;
  30. }
  31. } else {
  32. - if (len <= *var_bufsize) {
  33. + if (len <= *var_bufsize && check_flag) {
  34. ret = SNMP_ERR_NOERROR;
  35. }
  36. }
  37. @@ -358,6 +366,9 @@ system_set_value(const struct snmp_scalar_array_node_def *node, u16_t len, void
  38. } else {
  39. *var_wr_len = len;
  40. }
  41. +#ifdef SNMP_SYS_PARAM_SAVE
  42. + SNMP_SYS_PARAM_SAVE();
  43. +#endif
  44. return SNMP_ERR_NOERROR;
  45. }