18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * This file is provided under a dual BSD/GPLv2 license. When using or 48c2ecf20Sopenharmony_ci * redistributing this file, you may do so under either license. 58c2ecf20Sopenharmony_ci * 68c2ecf20Sopenharmony_ci * Copyright(c) 2018 Intel Corporation. All rights reserved. 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ci/* 108c2ecf20Sopenharmony_ci * Firmware file format . 118c2ecf20Sopenharmony_ci */ 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#ifndef __INCLUDE_UAPI_SOF_FW_H__ 148c2ecf20Sopenharmony_ci#define __INCLUDE_UAPI_SOF_FW_H__ 158c2ecf20Sopenharmony_ci 168c2ecf20Sopenharmony_ci#include <linux/types.h> 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_ci#define SND_SOF_FW_SIG_SIZE 4 198c2ecf20Sopenharmony_ci#define SND_SOF_FW_ABI 1 208c2ecf20Sopenharmony_ci#define SND_SOF_FW_SIG "Reef" 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_ci/* 238c2ecf20Sopenharmony_ci * Firmware module is made up of 1 . N blocks of different types. The 248c2ecf20Sopenharmony_ci * Block header is used to determine where and how block is to be copied in the 258c2ecf20Sopenharmony_ci * DSP/host memory space. 268c2ecf20Sopenharmony_ci */ 278c2ecf20Sopenharmony_cienum snd_sof_fw_blk_type { 288c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_INVALID = -1, 298c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_START = 0, 308c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD0 = SOF_FW_BLK_TYPE_START, 318c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_IRAM = 1, /* local instruction RAM */ 328c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_DRAM = 2, /* local data RAM */ 338c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_SRAM = 3, /* system RAM */ 348c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_ROM = 4, 358c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_IMR = 5, 368c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD6 = 6, 378c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD7 = 7, 388c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD8 = 8, 398c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD9 = 9, 408c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD10 = 10, 418c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD11 = 11, 428c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD12 = 12, 438c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD13 = 13, 448c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_RSRVD14 = 14, 458c2ecf20Sopenharmony_ci /* use SOF_FW_BLK_TYPE_RSVRDX for new block types */ 468c2ecf20Sopenharmony_ci SOF_FW_BLK_TYPE_NUM 478c2ecf20Sopenharmony_ci}; 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_cistruct snd_sof_blk_hdr { 508c2ecf20Sopenharmony_ci enum snd_sof_fw_blk_type type; 518c2ecf20Sopenharmony_ci __u32 size; /* bytes minus this header */ 528c2ecf20Sopenharmony_ci __u32 offset; /* offset from base */ 538c2ecf20Sopenharmony_ci} __packed; 548c2ecf20Sopenharmony_ci 558c2ecf20Sopenharmony_ci/* 568c2ecf20Sopenharmony_ci * Firmware file is made up of 1 .. N different modules types. The module 578c2ecf20Sopenharmony_ci * type is used to determine how to load and parse the module. 588c2ecf20Sopenharmony_ci */ 598c2ecf20Sopenharmony_cienum snd_sof_fw_mod_type { 608c2ecf20Sopenharmony_ci SOF_FW_BASE = 0, /* base firmware image */ 618c2ecf20Sopenharmony_ci SOF_FW_MODULE = 1, /* firmware module */ 628c2ecf20Sopenharmony_ci}; 638c2ecf20Sopenharmony_ci 648c2ecf20Sopenharmony_cistruct snd_sof_mod_hdr { 658c2ecf20Sopenharmony_ci enum snd_sof_fw_mod_type type; 668c2ecf20Sopenharmony_ci __u32 size; /* bytes minus this header */ 678c2ecf20Sopenharmony_ci __u32 num_blocks; /* number of blocks */ 688c2ecf20Sopenharmony_ci} __packed; 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ci/* 718c2ecf20Sopenharmony_ci * Firmware file header. 728c2ecf20Sopenharmony_ci */ 738c2ecf20Sopenharmony_cistruct snd_sof_fw_header { 748c2ecf20Sopenharmony_ci unsigned char sig[SND_SOF_FW_SIG_SIZE]; /* "Reef" */ 758c2ecf20Sopenharmony_ci __u32 file_size; /* size of file minus this header */ 768c2ecf20Sopenharmony_ci __u32 num_modules; /* number of modules */ 778c2ecf20Sopenharmony_ci __u32 abi; /* version of header format */ 788c2ecf20Sopenharmony_ci} __packed; 798c2ecf20Sopenharmony_ci 808c2ecf20Sopenharmony_ci#endif 81