2012-10-04 16:31:52 +01:00
/*
* wmfw . h - Wolfson firmware format information
*
* Copyright 2012 Wolfson Microelectronics plc
*
* Author : Mark Brown < broonie @ opensource . wolfsonmicro . com >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# ifndef __WMFW_H
# define __WMFW_H
# include <linux/types.h>
2015-04-13 13:28:02 +01:00
# define WMFW_MAX_ALG_NAME 256
# define WMFW_MAX_ALG_DESCR_NAME 256
# define WMFW_MAX_COEFF_NAME 256
# define WMFW_MAX_COEFF_DESCR_NAME 256
2015-04-20 13:52:45 +01:00
# define WMFW_CTL_FLAG_SYS 0x8000
# define WMFW_CTL_FLAG_VOLATILE 0x0004
# define WMFW_CTL_FLAG_WRITEABLE 0x0002
# define WMFW_CTL_FLAG_READABLE 0x0001
2016-11-09 17:14:17 +00:00
/* Non-ALSA coefficient types start at 0x1000 */
2016-11-09 17:14:18 +00:00
# define WMFW_CTL_TYPE_ACKED 0x1000 /* acked control */
2016-11-09 17:14:17 +00:00
# define WMFW_CTL_TYPE_HOSTEVENT 0x1001 /* event control */
2018-07-19 11:50:39 +01:00
# define WMFW_CTL_TYPE_HOST_BUFFER 0x1002 /* host buffer pointer */
2016-11-09 17:14:17 +00:00
2012-10-04 16:31:52 +01:00
struct wmfw_header {
char magic [ 4 ] ;
__le32 len ;
__le16 rev ;
u8 core ;
u8 ver ;
} __packed ;
struct wmfw_footer {
__le64 timestamp ;
__le32 checksum ;
} __packed ;
struct wmfw_adsp1_sizes {
__le32 dm ;
__le32 pm ;
__le32 zm ;
} __packed ;
2012-10-11 11:54:02 +09:00
struct wmfw_adsp2_sizes {
__le32 xm ;
__le32 ym ;
__le32 pm ;
__le32 zm ;
} __packed ;
2012-10-04 16:31:52 +01:00
struct wmfw_region {
union {
__be32 type ;
__le32 offset ;
} ;
__le32 len ;
u8 data [ ] ;
} __packed ;
2012-10-05 19:43:18 +01:00
struct wmfw_id_hdr {
__be32 core_id ;
__be32 core_rev ;
__be32 id ;
__be32 ver ;
} __packed ;
2019-03-19 11:52:13 +00:00
struct wmfw_v3_id_hdr {
__be32 core_id ;
__be32 block_rev ;
__be32 vendor_id ;
__be32 id ;
__be32 ver ;
} __packed ;
2012-10-05 19:43:18 +01:00
struct wmfw_adsp1_id_hdr {
struct wmfw_id_hdr fw ;
__be32 zm ;
__be32 dm ;
2015-04-13 13:27:54 +01:00
__be32 n_algs ;
2012-10-05 19:43:18 +01:00
} __packed ;
2012-10-11 11:54:02 +09:00
struct wmfw_adsp2_id_hdr {
struct wmfw_id_hdr fw ;
__be32 zm ;
__be32 xm ;
__be32 ym ;
2015-04-13 13:27:54 +01:00
__be32 n_algs ;
2012-10-11 11:54:02 +09:00
} __packed ;
2019-03-19 11:52:13 +00:00
struct wmfw_halo_id_hdr {
struct wmfw_v3_id_hdr fw ;
__be32 xm_base ;
__be32 xm_size ;
__be32 ym_base ;
__be32 ym_size ;
__be32 n_algs ;
} __packed ;
2012-10-05 19:43:18 +01:00
struct wmfw_alg_hdr {
__be32 id ;
__be32 ver ;
} __packed ;
struct wmfw_adsp1_alg_hdr {
struct wmfw_alg_hdr alg ;
__be32 zm ;
__be32 dm ;
} __packed ;
2012-10-11 11:54:02 +09:00
struct wmfw_adsp2_alg_hdr {
struct wmfw_alg_hdr alg ;
__be32 zm ;
__be32 xm ;
__be32 ym ;
} __packed ;
2019-03-19 11:52:13 +00:00
struct wmfw_halo_alg_hdr {
struct wmfw_alg_hdr alg ;
__be32 xm_base ;
__be32 xm_size ;
__be32 ym_base ;
__be32 ym_size ;
} __packed ;
2015-04-13 13:28:02 +01:00
struct wmfw_adsp_alg_data {
__le32 id ;
u8 name [ WMFW_MAX_ALG_NAME ] ;
u8 descr [ WMFW_MAX_ALG_DESCR_NAME ] ;
__le32 ncoeff ;
u8 data [ ] ;
} __packed ;
struct wmfw_adsp_coeff_data {
struct {
__le16 offset ;
__le16 type ;
__le32 size ;
} hdr ;
u8 name [ WMFW_MAX_COEFF_NAME ] ;
u8 descr [ WMFW_MAX_COEFF_DESCR_NAME ] ;
__le16 ctl_type ;
__le16 flags ;
__le32 len ;
u8 data [ ] ;
} __packed ;
2012-10-05 19:43:18 +01:00
struct wmfw_coeff_hdr {
u8 magic [ 4 ] ;
__le32 len ;
2013-01-16 16:59:04 +09:00
union {
__be32 rev ;
__le32 ver ;
} ;
union {
__be32 core ;
__le32 core_ver ;
} ;
2012-10-05 19:43:18 +01:00
u8 data [ ] ;
} __packed ;
struct wmfw_coeff_item {
2013-01-16 16:59:04 +09:00
__le16 offset ;
__le16 type ;
2012-10-05 19:43:18 +01:00
__le32 id ;
__le32 ver ;
__le32 sr ;
__le32 len ;
u8 data [ ] ;
} __packed ;
2012-10-11 11:54:02 +09:00
2012-10-04 16:31:52 +01:00
# define WMFW_ADSP1 1
2012-10-11 11:54:02 +09:00
# define WMFW_ADSP2 2
2019-03-19 11:52:13 +00:00
# define WMFW_HALO 4
2012-10-04 16:31:52 +01:00
2015-04-13 13:28:02 +01:00
# define WMFW_ABSOLUTE 0xf0
# define WMFW_ALGORITHM_DATA 0xf2
# define WMFW_NAME_TEXT 0xfe
# define WMFW_INFO_TEXT 0xff
2012-10-04 16:31:52 +01:00
# define WMFW_ADSP1_PM 2
# define WMFW_ADSP1_DM 3
# define WMFW_ADSP1_ZM 4
2012-10-11 11:54:02 +09:00
# define WMFW_ADSP2_PM 2
# define WMFW_ADSP2_ZM 4
# define WMFW_ADSP2_XM 5
# define WMFW_ADSP2_YM 6
2019-03-19 11:52:13 +00:00
# define WMFW_HALO_PM_PACKED 0x10
# define WMFW_HALO_XM_PACKED 0x11
# define WMFW_HALO_YM_PACKED 0x12
2012-10-04 16:31:52 +01:00
# endif