Home | History | Annotate | Download | only in test
      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 
     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