ipa_nat_test005.c 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (c) 2014, 2018-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions are
  6. * met:
  7. * * Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * * Redistributions in binary form must reproduce the above
  10. * copyright notice, this list of conditions and the following
  11. * disclaimer in the documentation and/or other materials provided
  12. * with the distribution.
  13. * * Neither the name of The Linux Foundation nor the names of its
  14. * contributors may be used to endorse or promote products derived
  15. * from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
  18. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  19. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
  20. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
  21. * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  22. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  23. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
  24. * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  25. * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
  26. * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
  27. * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  28. */
  29. /*=========================================================================*/
  30. /*!
  31. @file
  32. ipa_nat_test005.c
  33. @brief
  34. Verify the following scenario:
  35. 1. Add ipv4 table
  36. 2. Add ipv4 rule
  37. 3. Delete ipv4 rule
  38. 4. Add ipv4 rule
  39. 5. Delete ipv4 table
  40. */
  41. /*=========================================================================*/
  42. #include "ipa_nat_test.h"
  43. int ipa_nat_test005(
  44. const char* nat_mem_type,
  45. u32 pub_ip_add,
  46. int total_entries,
  47. u32 tbl_hdl,
  48. int sep,
  49. void* arb_data_ptr)
  50. {
  51. int* tbl_hdl_ptr = (int*) arb_data_ptr;
  52. ipa_nat_ipv4_rule ipv4_rule = {0};
  53. u32 rule_hdl;
  54. int ret;
  55. ipv4_rule.target_ip = RAN_ADDR;
  56. ipv4_rule.target_port = RAN_PORT;
  57. ipv4_rule.private_ip = RAN_ADDR;
  58. ipv4_rule.private_port = RAN_PORT;
  59. ipv4_rule.protocol = IPPROTO_TCP;
  60. ipv4_rule.public_port = RAN_PORT;
  61. IPADBG("In\n");
  62. if ( sep )
  63. {
  64. ret = ipa_nat_add_ipv4_tbl(pub_ip_add, nat_mem_type, total_entries, &tbl_hdl);
  65. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  66. }
  67. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl);
  68. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  69. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl);
  70. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  71. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl);
  72. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  73. if ( sep )
  74. {
  75. ret = ipa_nat_del_ipv4_tbl(tbl_hdl);
  76. *tbl_hdl_ptr = 0;
  77. CHECK_ERR(ret);
  78. }
  79. IPADBG("Out\n");
  80. return 0;
  81. }