ipa_nat_test017.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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_test017.cpp
  33. @brief
  34. Verify the following scenario:
  35. 1. Add ipv4 table
  36. 2. add same 3 ipv rules
  37. 3. delete second, third and first
  38. 4. Delete ipv4 table
  39. */
  40. /*=========================================================================*/
  41. #include "ipa_nat_test.h"
  42. int ipa_nat_test017(
  43. const char* nat_mem_type,
  44. u32 pub_ip_add,
  45. int total_entries,
  46. u32 tbl_hdl,
  47. int sep,
  48. void* arb_data_ptr)
  49. {
  50. int* tbl_hdl_ptr = (int*) arb_data_ptr;
  51. int ret;
  52. u32 rule_hdl1, rule_hdl2, rule_hdl3;
  53. ipa_nat_ipv4_rule ipv4_rule = {0};
  54. ipv4_rule.target_ip = RAN_ADDR;
  55. ipv4_rule.target_port = RAN_PORT;
  56. ipv4_rule.private_ip = RAN_ADDR;
  57. ipv4_rule.private_port = RAN_PORT;
  58. ipv4_rule.protocol = IPPROTO_TCP;
  59. ipv4_rule.public_port = RAN_PORT;
  60. IPADBG("In\n");
  61. if ( sep )
  62. {
  63. ret = ipa_nat_add_ipv4_tbl(pub_ip_add, nat_mem_type, total_entries, &tbl_hdl);
  64. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  65. }
  66. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl1);
  67. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  68. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl2);
  69. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  70. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl3);
  71. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  72. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl2);
  73. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  74. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl3);
  75. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  76. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl1);
  77. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  78. if ( sep )
  79. {
  80. ret = ipa_nat_del_ipv4_tbl(tbl_hdl);
  81. *tbl_hdl_ptr = 0;
  82. CHECK_ERR(ret);
  83. }
  84. IPADBG("Out\n");
  85. return 0;
  86. }