Kolla: Add support for cinder on device

Add support for an actual HDD or device, instead of loopback

installer-type: kolla
deploy-scenario: os-nosdn-nofeature

Change-Id: If1f8d24294704b81d6d8b22a8126db36fc10f96f
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/main.yml b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/main.yml
index 3a02d5f..783f029 100644
--- a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/main.yml
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/main.yml
@@ -22,7 +22,7 @@
 - include: sync-time.yml
 - include: create-swap.yml
 - include: prepare-nova-kvm.yml
-- include: prepare-cinder-{{ cinder_storage_driver }}.yml
+- include: prepare-cinder-{{ cinder_storage_driver }}-{{ cinder_storage_type }}.yml
 - include: prepare-cinder-backup-{{ cinder_storage_backup_driver }}.yml
 
 # vim: set ts=2 sw=2 expandtab:
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-device.yml b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-device.yml
new file mode 100644
index 0000000..f9660f9
--- /dev/null
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-device.yml
@@ -0,0 +1,41 @@
+---
+# ============LICENSE_START=======================================================
+#  Copyright (C) 2019 The Nordix Foundation. All rights reserved.
+# ================================================================================
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
+# ============LICENSE_END=========================================================
+
+- name: Read "{{ cinder_volume_device }}" volume information
+  parted:
+    device: "{{ cinder_volume_device }}"
+    unit: "MiB"
+  register: device_info
+
+- name: Remove all partitions from disk
+  parted:
+    device: "{{ cinder_volume_device }}"
+    number: '{{ item.num }}'
+    state: absent
+  loop: '{{ device_info.partitions }}'
+
+- name: Create Ceph RBD partition
+  parted:
+    label: gpt
+    state: present
+    device: "{{ cinder_volume_device }}"
+    number: 1
+    name: "{{ ceph_partition_name }}"
+
+# vim: set ts=2 sw=2 expandtab:
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph.yml b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-loopback.yml
similarity index 91%
rename from engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph.yml
rename to engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-loopback.yml
index d308eab..f14862e 100644
--- a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph.yml
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-ceph-loopback.yml
@@ -19,7 +19,7 @@
 
 - name: Check for cinder image
   stat:
-    path: "{{ cinder_image_path }}"
+    path: "{{ cinder_volume_path }}"
   register: cinder_image
   ignore_errors: true
 
@@ -35,7 +35,7 @@
 
     - name: Remove cinder image
       file:
-        path: "{{ cinder_image_path }}"
+        path: "{{ cinder_volume_path }}"
         state: absent
       ignore_errors: true
   when: cinder_image.stat.exists
@@ -50,9 +50,9 @@
     loopback_device_name: "{{ free_device.stdout }}"
 
 - name: Create cinder image
-  command: "fallocate -l {{ cinder_image_size }} {{ cinder_image_path }}"
+  command: "fallocate -l {{ cinder_volume_size }} {{ cinder_volume_path }}"
   args:
-    creates: "{{ cinder_image_path }}"
+    creates: "{{ cinder_volume_path }}"
 
 - name: Create cinder loopback service
   template:
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-device.yml b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-device.yml
new file mode 100644
index 0000000..d7bd99c
--- /dev/null
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-device.yml
@@ -0,0 +1,32 @@
+---
+# ============LICENSE_START=======================================================
+#  Copyright (C) 2019 The Nordix Foundation. All rights reserved.
+# ================================================================================
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+# SPDX-License-Identifier: Apache-2.0
+# ============LICENSE_END=========================================================
+
+- name: Remove cinder-volumes volume group if it exists
+  lvg:
+    vg: cinder-volumes
+    state: absent
+    force: true
+  ignore_errors: true
+
+- name: Add cinder-volumes volume group
+  lvg:
+    vg: cinder-volumes
+    pvs: "{{ cinder_volume_device }}"
+
+# vim: set ts=2 sw=2 expandtab:
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm.yml b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-loopback.yml
similarity index 92%
rename from engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm.yml
rename to engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-loopback.yml
index 58dbd99..7230c44 100644
--- a/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm.yml
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/tasks/prepare-cinder-lvm-loopback.yml
@@ -28,7 +28,7 @@
 
 - name: Check for cinder image
   stat:
-    path: "{{ cinder_image_path }}"
+    path: "{{ cinder_volume_path }}"
   register: cinder_image
   ignore_errors: true
 
@@ -48,7 +48,7 @@
 
     - name: Remove cinder image
       file:
-        path: "{{ cinder_image_path }}"
+        path: "{{ cinder_volume_path }}"
         state: absent
       ignore_errors: true
   when: cinder_image.stat.exists
@@ -63,9 +63,9 @@
     loopback_device_name: "{{ free_device.stdout }}"
 
 - name: Create cinder image
-  command: "fallocate -l {{ cinder_image_size }} {{ cinder_image_path }}"
+  command: "fallocate -l {{ cinder_volume_size }} {{ cinder_volume_path }}"
   args:
-    creates: "{{ cinder_image_path }}"
+    creates: "{{ cinder_volume_path }}"
 
 - name: Create cinder loopback service
   template:
diff --git a/engine/installer/kolla/playbooks/roles/configure-targethosts/templates/cinder-loopback.service.j2 b/engine/installer/kolla/playbooks/roles/configure-targethosts/templates/cinder-loopback.service.j2
index 6f47739..0cc0bea 100644
--- a/engine/installer/kolla/playbooks/roles/configure-targethosts/templates/cinder-loopback.service.j2
+++ b/engine/installer/kolla/playbooks/roles/configure-targethosts/templates/cinder-loopback.service.j2
@@ -6,7 +6,7 @@
 Wants=systemd-udev-settle.service
 
 [Service]
-ExecStart=/sbin/losetup {{ loopback_device_name }} {{ cinder_image_path }}
+ExecStart=/sbin/losetup {{ loopback_device_name }} {{ cinder_volume_path }}
 Type=oneshot
 
 [Install]
diff --git a/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_rocky.ini.j2 b/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_rocky.ini.j2
index 5162f55..fe76983 100644
--- a/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_rocky.ini.j2
+++ b/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_rocky.ini.j2
@@ -1,10 +1,17 @@
 [all:vars]
 ansible_ssh_extra_args=' -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null'
-cinder_image_path='/var/lib/cinder.img'
 cinder_backup_path='/mnt/cinder-backup'
 cinder_storage_driver='{{ idf.kolla.storage.driver }}'
 cinder_storage_backup_driver='{{ idf.kolla.storage.backup_driver }}'
-cinder_image_size='{{ idf.kolla.storage.volume.size }}'
+{% if idf.kolla.storage.volume.size is defined %}
+cinder_storage_type='loopback'
+cinder_volume_path='/var/lib/cinder.img'
+cinder_volume_size='{{ idf.kolla.storage.volume.size }}'
+{% endif %}
+{% if idf.kolla.storage.volume.device is defined %}
+cinder_storage_type='device'
+cinder_volume_device='{{ idf.kolla.storage.volume.device }}'
+{% endif %}
 
 [baremetal]
 {% for node in nodes %}
diff --git a/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_stein.ini.j2 b/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_stein.ini.j2
index 20031bd..6d78f6b 100644
--- a/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_stein.ini.j2
+++ b/engine/provisioner/bifrost/playbooks/roles/generate-inventory/templates/inventory_kolla_stein.ini.j2
@@ -1,10 +1,17 @@
 [all:vars]
 ansible_ssh_extra_args=' -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null'
-cinder_image_path='/var/lib/cinder.img'
 cinder_backup_path='/mnt/cinder-backup'
 cinder_storage_driver='{{ idf.kolla.storage.driver }}'
 cinder_storage_backup_driver='{{ idf.kolla.storage.backup_driver }}'
-cinder_image_size='{{ idf.kolla.storage.volume.size }}'
+{% if idf.kolla.storage.volume.size is defined %}
+cinder_storage_type='loopback'
+cinder_volume_path='/var/lib/cinder.img'
+cinder_volume_size='{{ idf.kolla.storage.volume.size }}'
+{% endif %}
+{% if idf.kolla.storage.volume.device is defined %}
+cinder_storage_type='device'
+cinder_volume_device='{{ idf.kolla.storage.volume.device }}'
+{% endif %}
 
 [baremetal]
 {% for node in nodes %}