<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Title" content="">
<meta name="Keywords" content="">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Arial;
        panose-1:2 11 6 4 2 2 2 2 2 4;}
@font-face
        {font-family:"Courier New";
        panose-1:2 7 3 9 2 2 5 2 4 4;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:Calibri;}
h2
        {mso-style-priority:9;
        mso-style-link:"Heading 2 Char";
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:18.0pt;
        font-family:"Times New Roman";
        font-weight:bold;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        mso-margin-top-alt:auto;
        margin-right:0in;
        mso-margin-bottom-alt:auto;
        margin-left:0in;
        font-size:12.0pt;
        font-family:"Times New Roman";}
code
        {mso-style-priority:99;
        font-family:"Courier New";}
pre
        {mso-style-priority:99;
        mso-style-link:"HTML Preformatted Char";
        margin:0in;
        margin-bottom:.0001pt;
        font-size:10.0pt;
        font-family:"Courier New";}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:Calibri;
        color:windowtext;}
span.Heading2Char
        {mso-style-name:"Heading 2 Char";
        mso-style-priority:9;
        mso-style-link:"Heading 2";
        font-family:"Times New Roman";
        font-weight:bold;}
span.z-TopofFormChar
        {mso-style-name:"z-Top of Form Char";
        mso-style-priority:99;
        mso-style-link:"z-Top of Form";
        font-family:Arial;
        display:none;}
span.apple-converted-space
        {mso-style-name:apple-converted-space;}
span.HTMLPreformattedChar
        {mso-style-name:"HTML Preformatted Char";
        mso-style-priority:99;
        mso-style-link:"HTML Preformatted";
        font-family:"Courier New";}
span.z-BottomofFormChar
        {mso-style-name:"z-Bottom of Form Char";
        mso-style-priority:99;
        mso-style-link:"z-Bottom of Form";
        font-family:Arial;
        display:none;}
span.msoIns
        {mso-style-type:export-only;
        mso-style-name:"";
        text-decoration:underline;
        color:teal;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:Calibri;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:668674186;
        mso-list-template-ids:-719268262;}
@list l0:level1
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level2
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level5
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level8
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style>
</head>
<body bgcolor="white" lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">* Libreswan 3.15 ipsec (libreswan-3.15-5.el7_1.x86_64)<o:p></o:p></p>
<p class="MsoNormal">* Openstack Icehouse<o:p></o:p></p>
<p class="MsoNormal">* RHEL 7.1 boxes used as routers<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Followed this document (with modifications) https://libreswan.org/wiki/Subnet_to_subnet_VPN_with_PSK<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I am attempting to create libreswan ipsec tunnels between tenants in an Openstack Icehouse cloud.  I have created a shared subnet (10.255.255.0/24) that the RHEL boxes attach to in a multi-homed fashion.  Each box has two interfaces. net.ipv4.ip_forward
 is enabled (1) on each box.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    Router in tenant A                           Router in tenant B<o:p></o:p></p>
<p class="MsoNormal">    ------------------------                     ------------------------<o:p></o:p></p>
<p class="MsoNormal">    eth0      eth1           <=================> eth1           eth0<o:p></o:p></p>
<p class="MsoNormal">    10.0.1.1  10.255.255.10                      10.255.255.20  10.0.2.1<o:p></o:p></p>
<p class="MsoNormal">    ------------------------                     ------------------------<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Routing<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    Tenant A: 10.0.1.0/24<o:p></o:p></p>
<p class="MsoNormal">       * Subnet hosts use gateway: 10.0.1.1<o:p></o:p></p>
<p class="MsoNormal">    Tenant B: 10.0.2.0/24<o:p></o:p></p>
<p class="MsoNormal">       * Subnet hosts use gateway: 10.0.2.1<o:p></o:p></p>
<p class="MsoNormal">    Shared segment: 10.255.255.0/24<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    10.0.2.0/24 via 10.255.255.20                <o:p></o:p></p>
<p class="MsoNormal">    10.0.1.0/24 via 10.255.255.10<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">I've setup the VM ports to allow tenant A's network to be announced on Tenant B's eth0 interface, and vice-versa, by setting the port's allowed_address_pairs to the opposite network's range (this is an Openstack-ism).  I can connect (ping,ssh)
 across the shared network to arbitrary hosts on the other end.  This all works without libreswan in the middle.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I add libreswan, and things break.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Libreswan config router tenant A<o:p></o:p></p>
<p class="MsoNormal">--------------------------------<o:p></o:p></p>
<p class="MsoNormal">    config setup<o:p></o:p></p>
<p class="MsoNormal">        protostack=netkey<o:p></o:p></p>
<p class="MsoNormal">        plutodebug=all<o:p></o:p></p>
<p class="MsoNormal">        plutorestartoncrash=yes<o:p></o:p></p>
<p class="MsoNormal">        dumpdir=/var/run/pluto<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">    conn base<o:p></o:p></p>
<p class="MsoNormal">        authby=rsasig<o:p></o:p></p>
<p class="MsoNormal">        left=10.255.255.10<o:p></o:p></p>
<p class="MsoNormal">        leftsourceip=10.0.1.1<o:p></o:p></p>
<p class="MsoNormal">        leftsubnet=10.0.1.0/24<o:p></o:p></p>
<p class="MsoNormal">        leftrsasigkey=<redacted><o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">    tenant_a<o:p></o:p></p>
<p class="MsoNormal">        also=base<o:p></o:p></p>
<p class="MsoNormal">        right=10.255.255.10<o:p></o:p></p>
<p class="MsoNormal">        rightsubnet=10.0.2.0/24<o:p></o:p></p>
<p class="MsoNormal">        rightrsasigkey=<redacted><o:p></o:p></p>
<p class="MsoNormal">        auto=start<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">Libreswan config router tenant B<o:p></o:p></p>
<p class="MsoNormal">--------------------------------<o:p></o:p></p>
<p class="MsoNormal">    config setup<o:p></o:p></p>
<p class="MsoNormal">        protostack=netkey<o:p></o:p></p>
<p class="MsoNormal">        plutodebug=all<o:p></o:p></p>
<p class="MsoNormal">        plutorestartoncrash=yes<o:p></o:p></p>
<p class="MsoNormal">        dumpdir=/var/run/pluto<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">    conn base<o:p></o:p></p>
<p class="MsoNormal">        authby=rsasig<o:p></o:p></p>
<p class="MsoNormal">        left=10.255.255.20<o:p></o:p></p>
<p class="MsoNormal">        leftsourceip=10.0.2.1<o:p></o:p></p>
<p class="MsoNormal">        leftsubnet=10.0.2.0/24<o:p></o:p></p>
<p class="MsoNormal">       leftrsasigkey=<redacted><o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">    tenant_b<o:p></o:p></p>
<p class="MsoNormal">        also=base<o:p></o:p></p>
<p class="MsoNormal">        right=10.255.255.20<o:p></o:p></p>
<p class="MsoNormal">        rightsubnet=10.0.1.0/24<o:p></o:p></p>
<p class="MsoNormal">        rightrsasigkey=<redacted><o:p></o:p></p>
<p class="MsoNormal">        auto=start<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">Running this config on each end has the tunnel coming up without any errors.  When the tunnel comes up, libreswan adds a new route with a higher priority than the initial static route:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">     10.0.2.0/24 dev eth1  scope link  src 10.0.1.1<o:p></o:p></p>
<p class="MsoNormal">     10.0.2.0/24 via 10.255.255.20 dev eth1  proto static  metric 100<o:p></o:p></p>
<p class="MsoNormal">        <o:p></o:p></p>
<p class="MsoNormal">and the same on the remote end:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    10.0.1.0/24 dev eth1  scope link  src 10.0.2.1<o:p></o:p></p>
<p class="MsoNormal">    10.0.1.0/24 via 10.255.255.10 dev eth1  proto static  metric 100<o:p></o:p></p>
<p class="MsoNormal">    <o:p></o:p></p>
<p class="MsoNormal">I can ping the remote router's eth0 interface IP address but not any hosts in the remote subnet.  This is true from either direction. 
<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">With this config, i can reach the remote end:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">    traceroute to 10.0.2.1 (10.0.2.1), 64 hops max, 52 byte packets<o:p></o:p></p>
<p class="MsoNormal">     1  172.31.228.1 (172.31.228.1)  29.907 ms  29.742 ms  29.888 ms<o:p></o:p></p>
<p class="MsoNormal">     2  10.0.1.1 (10.0.1.1)  30.338 ms  29.795 ms  29.985 ms<o:p></o:p></p>
<p class="MsoNormal">     3  10.0.2.1 (10.0.2.1)  29.645 ms  30.893 ms  30.823 ms<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">But cannot route past 10.0.2.1.  I get a 'Network unreachable' error:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">     1  172.31.228.1 (172.31.228.1)  29.907 ms  29.742 ms  29.888 ms<o:p></o:p></p>
<p class="MsoNormal">     2  10.0.1.1 (10.0.1.1)  30.338 ms  29.795 ms  29.985 ms<o:p></o:p></p>
<p class="MsoNormal">     3  10.0.1.1 (10.0.1.1)  3035.382 ms  !H 30.893 ms  30.823 ms</p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Any idea what is going on here?<o:p></o:p></p>
</div>
</body>
</html>