| // Copyright 2018 The Fuchsia Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #pragma once |
| |
| #include <fbl/string.h> |
| #include <fbl/unique_fd.h> |
| #include <fuchsia/paver/c/fidl.h> |
| #include <lib/zx/channel.h> |
| #include <zircon/types.h> |
| |
| namespace paver { |
| |
| // Writes a kernel or verified boot metadata payload to the appropriate |
| // partition. |
| zx_status_t WriteAsset(fuchsia_paver_Configuration configuration, fuchsia_paver_Asset asset, |
| const fuchsia_mem_Buffer& payload); |
| |
| // Writes volumes to the FVM partition. |
| zx_status_t WriteVolumes(zx::channel payload_stream); |
| |
| // Writes a bootloader image to the appropriate partition. |
| zx_status_t WriteBootloader(const fuchsia_mem_Buffer& payload); |
| |
| // Writes a file to the data minfs partition, managed by the FVM. |
| zx_status_t WriteDataFile(fbl::String filename, const fuchsia_mem_Buffer& payload); |
| |
| // Wipes all volumes from the FVM partition. |
| zx_status_t WipeVolumes(); |
| |
| } // namespace paver |