From 2a97154efddf09b9825fcf5bdd25feb77ec60395 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Harald=20Jens=C3=A5s?= Date: Mon, 1 Jun 2020 12:04:15 +0200 Subject: [PATCH] OVNChassisMacPorts for distributed VLAN For distributed vlan in ovn we need to add support of creating mac addresses per compute and seting them in external_ids:ovn-chassis-mac-mappings. This change passes the ovn::controller::ovn_bridge_mappings to the role node configuration so that ports for each bridge mapping can be created. The map of physnet/mac_address pairs is placed in the role output, and in RoleGroupVars. Related-Bug: #1881593 Change-Id: If24653b629e39b6dd7ec6d09ae0ef32d7842c48f (cherry picked from commit c90bbe188efafc3d4a073e8152d730b42af44b27) --- overcloud.j2.yaml | 1 + puppet/role.role.j2.yaml | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) diff --git a/overcloud.j2.yaml b/overcloud.j2.yaml index 0f1e6ae7e2..a0606fb464 100644 --- a/overcloud.j2.yaml +++ b/overcloud.j2.yaml @@ -770,6 +770,7 @@ resources: - {get_param: {{role.name}}SchedulerHints} ServiceNames: {get_attr: [{{role.name}}ServiceNames, value]} ServiceMetadataSettings: {get_attr: [{{role.name}}ServiceChainRoleData, value, service_metadata_settings]} + OVNBridgeMappings: {get_attr: [{{role.name}}ServiceChainRoleData, value, config_settings, 'ovn::controller::ovn_bridge_mappings']} DeploymentServerBlacklistDict: {get_attr: [DeploymentServerBlacklistDict, value]} RoleParameters: map_merge: diff --git a/puppet/role.role.j2.yaml b/puppet/role.role.j2.yaml index 2ab2f731a9..918bea13e9 100644 --- a/puppet/role.role.j2.yaml +++ b/puppet/role.role.j2.yaml @@ -117,6 +117,9 @@ parameters: ServiceMetadataSettings: type: json default: {} + OVNBridgeMappings: + type: comma_delimited_list + default: [] ConfigCommand: type: string description: Command which will be run whenever configuration data changes @@ -596,6 +599,37 @@ resources: fqdn_ctlplane: {get_attr: [NetHostMap, value, ctlplane, fqdn]} fqdn_canonical: {get_attr: [NetHostMap, value, canonical, fqdn]} hostname_resolve_network: {get_param: [ServiceNetMap, {{role.name}}HostnameResolveNetwork]} + ovn_chassis_mac_map: {get_attr: [{{server_resource_name}}OVNChassisMacMap, value]} + + {{server_resource_name}}OVNChassisMacPorts: + type: OS::Heat::ResourceGroup + properties: + count: + yaql: + expression: $.data.len() + data: {get_param: OVNBridgeMappings} + resource_def: + type: OS::TripleO::OVNMacAddressPort + properties: + PortName: {{server_resource_name}}-ovn-mac-%index% + + {{server_resource_name}}OVNChassisMacMap: + type: OS::Heat::Value + properties: + type: json + value: + yaql: + expression: let(physnets => switch(isList($.data.physnets) => $.data.physnets, true => [])) -> + $physnets.zip($.data.macs).toDict($.first(), $.last()) + data: + physnets: + yaql: + expression: $.data.select($.split(':').first()) + data: {get_param: OVNBridgeMappings} + macs: + yaql: + expression: switch(isDict($.data) => $.data.values(), true => []) + data: {get_attr: [{{server_resource_name}}OVNChassisMacPorts, attributes, mac_address]} outputs: ansible_host_vars_map: