ipa_nat_test006.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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_test006.c
  33. @brief
  34. Verify the following scenario:
  35. 1. Add ipv4 table
  36. 2. Add ipv rule
  37. 3. Add same ipv rule
  38. 4. Delete first followed by second
  39. 5. Delete ipv4 table
  40. */
  41. /*=========================================================================*/
  42. #include "ipa_nat_test.h"
  43. int ipa_nat_test006(
  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. u32 rule_hdl1;
  55. int ret;
  56. ipv4_rule.target_ip = RAN_ADDR;
  57. ipv4_rule.target_port = RAN_PORT;
  58. ipv4_rule.private_ip = RAN_ADDR;
  59. ipv4_rule.private_port = RAN_PORT;
  60. ipv4_rule.protocol = IPPROTO_TCP;
  61. ipv4_rule.public_port = RAN_PORT;
  62. IPADBG("In\n");
  63. if ( sep )
  64. {
  65. ret = ipa_nat_add_ipv4_tbl(pub_ip_add, nat_mem_type, total_entries, &tbl_hdl);
  66. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  67. }
  68. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl);
  69. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  70. ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl1);
  71. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  72. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl);
  73. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  74. ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl1);
  75. CHECK_ERR_TBL_STOP(ret, tbl_hdl);
  76. if ( sep )
  77. {
  78. ret = ipa_nat_del_ipv4_tbl(tbl_hdl);
  79. *tbl_hdl_ptr = 0;
  80. CHECK_ERR(ret);
  81. }
  82. IPADBG("Out\n");
  83. return 0;
  84. }