############################################################################## # Copyright (c) 2018 Mirantis Inc., Enea AB and others. # All rights reserved. This program and the accompanying materials # are made available under the terms of the Apache License, Version 2.0 # which accompanies this distribution, and is available at # http://www.apache.org/licenses/LICENSE-2.0 ############################################################################## {#- NOTE: br-{mgmt,ctl} are cross-referenced, careful when changing names #} {%- import 'net_map.j2' as nm with context %} {#- Filter-out NIC duplicates by constructing a dict (used NICs only) #} {%- set nics = { nm.cmp001.nic_admin: True, nm.cmp001.nic_mgmt: True } %} {%- set vlans = { nm.vlan_admin: nm.cmp001.nic_admin, nm.vlan_mgmt: nm.cmp001.nic_mgmt } %} --- parameters: _param: # Should later be determined via PDF/IDF, AArch64 has ESP on /dev/sda1 {%- if conf.nodes[nm.cmp001.idx].node.arch == 'aarch64' %} ~cinder_lvm_devices: [ '/dev/sda2' ] {%- else %} ~cinder_lvm_devices: [ '/dev/sda1' ] {%- endif %} linux: network: bridge: openvswitch interface: {%- for nic in nics %} {%- if nic == nm.cmp001.nic_admin %} {{ nic }}: enabled: true type: eth proto: dhcp name: {{ nic }} {%- else %} {{ nic }}: enabled: true type: eth proto: manual address: 0.0.0.0 {%- if nic == nm.cmp001.nic_public %} netmask: ${_param:opnfv_net_public_mask} {%- else %} netmask: 255.255.255.0 {%- endif %} mtu: ${_param:interface_mtu} name: {{ nic }} {%- endif %} {%- endfor %} {%- for vlan in vlans %} {%- if vlan and vlan != 'native' %} {{ vlans[vlan] }}.{{ vlan }}: enabled: true proto: manual type: vlan name: {{ vlans[vlan] }}.{{ vlan }} use_interfaces: - {{ vlans[vlan] }} {%- endif %} {%- endfor %} br-ctl: enabled: true type: bridge proto: static address: ${_param:single_address} netmask: 255.255.255.0 use_interfaces: - {{ nm.cmp001.nic_mgmt }}{% if nm.vlan_mgmt and nm.vlan_mgmt != 'native' %}.{{ nm.vlan_mgmt }}{% endif %} br-floating: enabled: true type: ovs_bridge mtu: ${_param:interface_mtu} br-ex: enabled: true type: ovs_port bridge: br-floating proto: static {%- if nm.vlan_public and nm.vlan_public != 'native' %} ovs_options: tag={{ nm.vlan_public }} {%- endif %} address: ${_param:external_address} netmask: 255.255.255.0 route: public: address: 0.0.0.0 netmask: 0.0.0.0 gateway: ${_param:opnfv_net_public_gw} {{ nm.cmp001.nic_public }}: enabled: true proto: manual ovs_port_type: OVSPort type: ovs_port ovs_bridge: br-floating bridge: br-floating