• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2014, 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 /*=========================================================================*/
32 /*!
33 	@file
34 	ipa_nat_test022.cpp
35 
36 	@brief
37 	Verify the following scenario:
38 	1. Add ipv4 table
39 	2. add same 3 ipv rules
40   3. delete Head and last entry
41   4. add 2 new same ip4 entries
42   5. Add head entry again
43 	6. Delete ipv4 table
44 */
45 /*=========================================================================*/
46 
47 #include "ipa_nat_test.h"
48 #include "ipa_nat_drv.h"
49 
ipa_nat_test022(int total_entries,u32 tbl_hdl,u8 sep)50 int ipa_nat_test022(int total_entries, u32 tbl_hdl, u8 sep)
51 {
52 	int ret;
53 	u32 rule_hdl1, rule_hdl2, rule_hdl3;
54 	ipa_nat_ipv4_rule ipv4_rule, ipv4_rule2;
55 	u32 rule_hdl21, rule_hdl22;
56 
57 	u32 pub_ip_add = 0x011617c0;   /* "192.23.22.1" */
58 
59 	/* Rule 1 */
60 	ipv4_rule.target_ip = 0xC1171601; /* 193.23.22.1 */
61 	ipv4_rule.target_port = 1234;
62 	ipv4_rule.private_ip = 0xC2171601; /* 194.23.22.1 */
63 	ipv4_rule.private_port = 5678;
64 	ipv4_rule.protocol = IPPROTO_TCP;
65 	ipv4_rule.public_port = 9050;
66 
67 	/* Rule 2*/
68 	ipv4_rule.target_ip = 0xC1171604; /* 193.23.22.4 */
69 	ipv4_rule.target_port = 1234;
70 	ipv4_rule.private_ip = 0xC2171603; /* 194.23.22.3 */
71 	ipv4_rule.private_port = 5680;
72 	ipv4_rule.protocol = IPPROTO_UDP;
73 	ipv4_rule.public_port = 9066;
74 
75 	IPADBG("%s():\n",__FUNCTION__);
76 
77 	if(sep)
78 	{
79 		ret = ipa_nat_add_ipv4_tbl(pub_ip_add, total_entries, &tbl_hdl);
80 		CHECK_ERR1(ret, tbl_hdl);
81 	}
82 
83 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl1);
84 	CHECK_ERR1(ret, tbl_hdl);
85 
86 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl2);
87 	CHECK_ERR1(ret, tbl_hdl);
88 
89 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl3);
90 	CHECK_ERR1(ret, tbl_hdl);
91 
92 	/* Delete head entry */
93 	ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl1);
94 	CHECK_ERR1(ret, tbl_hdl);
95 
96 	/* Delete Last Entry */
97 	ret = ipa_nat_del_ipv4_rule(tbl_hdl, rule_hdl3);
98 	CHECK_ERR1(ret, tbl_hdl);
99 
100 	/* Add 2 different Entries */
101 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule2, &rule_hdl21);
102 	CHECK_ERR1(ret, tbl_hdl);
103 
104 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule2, &rule_hdl22);
105 	CHECK_ERR1(ret, tbl_hdl);
106 
107 	/* Add first entry again */
108 	ret = ipa_nat_add_ipv4_rule(tbl_hdl, &ipv4_rule, &rule_hdl3);
109 	CHECK_ERR1(ret, tbl_hdl);
110 
111 	if(sep)
112 	{
113 		ret = ipa_nat_del_ipv4_tbl(tbl_hdl);
114 		CHECK_ERR1(ret, tbl_hdl);
115 	}
116 
117 	return 0;
118 }
119