ipa_nat_test007.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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_test007.cpp
  33. @brief
  34. Verify the following scenario:
  35. 1. Add ipv4 table
  36. 2. add same ipv rules
  37. 3. delete second followed by first
  38. 4. Delete ipv4 table
  39. */
  40. /*=========================================================================*/
  41. #include "ipa_nat_test.h"
  42. int ipa_nat_test007(
  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. ipa_nat_ipv4_rule ipv4_rule = {0};
  52. u32 rule_hdl;
  53. u32 rule_hdl1;
  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_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl1);
  70. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  71. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl1);
  72. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  73. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl);
  74. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  75. if ( sep )
  76. {
  77. ret = ipa_nat_del_ipv4_tbl(tbl_hdl);
  78. *tbl_hdl_ptr = 0;
  79. CHECK_ERR(ret);
  80. }
  81. IPADBG("Out\n");
  82. return 0;
  83. }