Commit 9deb52c6 authored by Shahar S Matityahu's avatar Shahar S Matityahu Committed by Luca Coelho

iwlwifi: dbg_ini: align struct iwl_fw_ini_region_cfg to the FW

New fields were added to struct iwl_fw_ini_region_cfg.
add those field and apply the changes the result from this change

offset field is used to differentiate between the different LMACs
and any memory access to the region addresses should be
base_addr + offset.

A fifo struct is to hold the meta data needed for fifo regions

Also move range_data_size and num_of_ranges into a struct under the
union to be aligned to the struct in the FW.
Signed-off-by: default avatarShahar S Matityahu <shahar.s.matityahu@intel.com>
Signed-off-by: default avatarLuca Coelho <luciano.coelho@intel.com>
parent 608dce95
...@@ -133,6 +133,33 @@ struct iwl_fw_ini_debug_flow_tlv { ...@@ -133,6 +133,33 @@ struct iwl_fw_ini_debug_flow_tlv {
#define IWL_FW_INI_MAX_REGION_ID 64 #define IWL_FW_INI_MAX_REGION_ID 64
#define IWL_FW_INI_MAX_NAME 32 #define IWL_FW_INI_MAX_NAME 32
/**
* struct iwl_fw_ini_region_cfg_internal - meta data of internal memory region
* @num_of_range: the amount of ranges in the region
* @range_data_size: size of the data to read per range, in bytes.
*/
struct iwl_fw_ini_region_cfg_internal {
__le32 num_of_ranges;
__le32 range_data_size;
} __packed; /* FW_DEBUG_TLV_REGION_NIC_INTERNAL_RANGES_S */
/**
* struct iwl_fw_ini_region_cfg_fifos - meta data of fifos region
* @lmac1_id: bit map of lmac1 fifos to include in the region.
* @lmac2_id: bit map of lmac2 fifos to include in the region.
* @num_of_registers: number of prph registers in the region, each register is
* 4 bytes size.
* @header_only: none zero value indicates that this region does not include
* fifo data and includes only the given registers.
*/
struct iwl_fw_ini_region_cfg_fifos {
__le32 lmac1_id;
__le32 lmac2_id;
__le32 num_of_registers;
__le32 header_only;
} __packed; /* FW_DEBUG_TLV_REGION_FIFOS_S */
/** /**
* struct iwl_fw_ini_region_cfg * struct iwl_fw_ini_region_cfg
* @region_id: ID of this dump configuration * @region_id: ID of this dump configuration
...@@ -140,11 +167,11 @@ struct iwl_fw_ini_debug_flow_tlv { ...@@ -140,11 +167,11 @@ struct iwl_fw_ini_debug_flow_tlv {
* @num_regions: amount of regions in the address array. * @num_regions: amount of regions in the address array.
* @name_len: name length * @name_len: name length
* @name: file name to use for this region * @name: file name to use for this region
* @num_of_range: the amount of ranges in the region. * @internal: used in case the region uses internal memory.
* @allocation_id: For DRAM type field substitutes for allocation_id * @allocation_id: For DRAM type field substitutes for allocation_id
* @range_data_size: size of the data to read per range, in bytes. * @fifos: used in case of fifos region.
* @start_addr: array of addresses. for type IWL_FW_INI_REGION_DRAM_BUFFER, * @offset: offset to use for each memory base address
* 1 entry. For any other case, num_of_ranges entries. * @start_addr: array of addresses.
*/ */
struct iwl_fw_ini_region_cfg { struct iwl_fw_ini_region_cfg {
__le32 region_id; __le32 region_id;
...@@ -152,10 +179,11 @@ struct iwl_fw_ini_region_cfg { ...@@ -152,10 +179,11 @@ struct iwl_fw_ini_region_cfg {
__le32 name_len; __le32 name_len;
u8 name[IWL_FW_INI_MAX_NAME]; u8 name[IWL_FW_INI_MAX_NAME];
union { union {
__le32 num_of_ranges; struct iwl_fw_ini_region_cfg_internal internal;
__le32 allocation_id; __le32 allocation_id;
struct iwl_fw_ini_region_cfg_fifos fifos;
}; };
__le32 range_data_size; __le32 offset;
__le32 start_addr[]; __le32 start_addr[];
} __packed; /* FW_DEBUG_TLV_REGION_CONFIG_S */ } __packed; /* FW_DEBUG_TLV_REGION_CONFIG_S */
......
...@@ -1068,7 +1068,7 @@ static void iwl_dump_prph_ini(struct iwl_trans *trans, ...@@ -1068,7 +1068,7 @@ static void iwl_dump_prph_ini(struct iwl_trans *trans,
{ {
struct iwl_fw_error_dump_prph *prph; struct iwl_fw_error_dump_prph *prph;
unsigned long flags; unsigned long flags;
u32 i, size = le32_to_cpu(reg->num_of_ranges); u32 i, size = le32_to_cpu(reg->internal.num_of_ranges);
IWL_DEBUG_INFO(trans, "WRT PRPH dump\n"); IWL_DEBUG_INFO(trans, "WRT PRPH dump\n");
...@@ -1077,7 +1077,8 @@ static void iwl_dump_prph_ini(struct iwl_trans *trans, ...@@ -1077,7 +1077,8 @@ static void iwl_dump_prph_ini(struct iwl_trans *trans,
for (i = 0; i < size; i++) { for (i = 0; i < size; i++) {
(*data)->type = cpu_to_le32(IWL_FW_ERROR_DUMP_PRPH); (*data)->type = cpu_to_le32(IWL_FW_ERROR_DUMP_PRPH);
(*data)->len = cpu_to_le32(le32_to_cpu(reg->range_data_size) + (*data)->len =
cpu_to_le32(le32_to_cpu(reg->internal.range_data_size) +
sizeof(*prph)); sizeof(*prph));
prph = (void *)(*data)->data; prph = (void *)(*data)->data;
prph->prph_start = reg->start_addr[i]; prph->prph_start = reg->start_addr[i];
...@@ -1092,8 +1093,8 @@ static void iwl_dump_csr_ini(struct iwl_trans *trans, ...@@ -1092,8 +1093,8 @@ static void iwl_dump_csr_ini(struct iwl_trans *trans,
struct iwl_fw_error_dump_data **data, struct iwl_fw_error_dump_data **data,
struct iwl_fw_ini_region_cfg *reg) struct iwl_fw_ini_region_cfg *reg)
{ {
int i, num = le32_to_cpu(reg->num_of_ranges); int i, num = le32_to_cpu(reg->internal.num_of_ranges);
u32 size = le32_to_cpu(reg->range_data_size); u32 size = le32_to_cpu(reg->internal.range_data_size);
IWL_DEBUG_INFO(trans, "WRT CSR dump\n"); IWL_DEBUG_INFO(trans, "WRT CSR dump\n");
...@@ -1136,13 +1137,13 @@ static int iwl_fw_ini_get_trigger_len(struct iwl_fw_runtime *fwrt, ...@@ -1136,13 +1137,13 @@ static int iwl_fw_ini_get_trigger_len(struct iwl_fw_runtime *fwrt,
continue; continue;
type = le32_to_cpu(reg->region_type); type = le32_to_cpu(reg->region_type);
num_entries = le32_to_cpu(reg->num_of_ranges); num_entries = le32_to_cpu(reg->internal.num_of_ranges);
switch (type) { switch (type) {
case IWL_FW_INI_REGION_DEVICE_MEMORY: case IWL_FW_INI_REGION_DEVICE_MEMORY:
size += hdr_len + size += hdr_len +
sizeof(struct iwl_fw_error_dump_named_mem) + sizeof(struct iwl_fw_error_dump_named_mem) +
le32_to_cpu(reg->range_data_size); le32_to_cpu(reg->internal.range_data_size);
break; break;
case IWL_FW_INI_REGION_PERIPHERY_MAC: case IWL_FW_INI_REGION_PERIPHERY_MAC:
case IWL_FW_INI_REGION_PERIPHERY_PHY: case IWL_FW_INI_REGION_PERIPHERY_PHY:
...@@ -1168,7 +1169,8 @@ static int iwl_fw_ini_get_trigger_len(struct iwl_fw_runtime *fwrt, ...@@ -1168,7 +1169,8 @@ static int iwl_fw_ini_get_trigger_len(struct iwl_fw_runtime *fwrt,
break; break;
case IWL_FW_INI_REGION_CSR: case IWL_FW_INI_REGION_CSR:
size += num_entries * size += num_entries *
(hdr_len + le32_to_cpu(reg->range_data_size)); (hdr_len +
le32_to_cpu(reg->internal.range_data_size));
break; break;
case IWL_FW_INI_REGION_DRAM_BUFFER: case IWL_FW_INI_REGION_DRAM_BUFFER:
/* Transport takes care of DRAM dumping */ /* Transport takes care of DRAM dumping */
...@@ -1204,15 +1206,20 @@ static void iwl_fw_ini_dump_trigger(struct iwl_fw_runtime *fwrt, ...@@ -1204,15 +1206,20 @@ static void iwl_fw_ini_dump_trigger(struct iwl_fw_runtime *fwrt,
type = le32_to_cpu(reg->region_type); type = le32_to_cpu(reg->region_type);
switch (type) { switch (type) {
case IWL_FW_INI_REGION_DEVICE_MEMORY: case IWL_FW_INI_REGION_DEVICE_MEMORY: {
if (WARN_ON(le32_to_cpu(reg->num_of_ranges) > 1)) u32 num_of_ranges =
le32_to_cpu(reg->internal.num_of_ranges);
u32 range_data_size =
le32_to_cpu(reg->internal.range_data_size);
if (WARN_ON(num_of_ranges) > 1)
continue; continue;
iwl_fw_dump_named_mem(fwrt, data, iwl_fw_dump_named_mem(fwrt, data, range_data_size,
le32_to_cpu(reg->range_data_size),
le32_to_cpu(reg->start_addr[0]), le32_to_cpu(reg->start_addr[0]),
reg->name, reg->name,
le32_to_cpu(reg->name_len)); le32_to_cpu(reg->name_len));
break; break;
}
case IWL_FW_INI_REGION_PERIPHERY_MAC: case IWL_FW_INI_REGION_PERIPHERY_MAC:
case IWL_FW_INI_REGION_PERIPHERY_PHY: case IWL_FW_INI_REGION_PERIPHERY_PHY:
case IWL_FW_INI_REGION_PERIPHERY_AUX: case IWL_FW_INI_REGION_PERIPHERY_AUX:
...@@ -1761,6 +1768,7 @@ static void iwl_fw_dbg_update_regions(struct iwl_fw_runtime *fwrt, ...@@ -1761,6 +1768,7 @@ static void iwl_fw_dbg_update_regions(struct iwl_fw_runtime *fwrt,
for (i = 0; i < size; i++) { for (i = 0; i < size; i++) {
struct iwl_fw_ini_region_cfg *reg = iter, **active; struct iwl_fw_ini_region_cfg *reg = iter, **active;
int id = le32_to_cpu(reg->region_id); int id = le32_to_cpu(reg->region_id);
u32 type = le32_to_cpu(reg->region_type);
if (WARN(id >= ARRAY_SIZE(fwrt->dump.active_regs), if (WARN(id >= ARRAY_SIZE(fwrt->dump.active_regs),
"Invalid region id %d for apply point %d\n", id, pnt)) "Invalid region id %d for apply point %d\n", id, pnt))
...@@ -1777,9 +1785,12 @@ static void iwl_fw_dbg_update_regions(struct iwl_fw_runtime *fwrt, ...@@ -1777,9 +1785,12 @@ static void iwl_fw_dbg_update_regions(struct iwl_fw_runtime *fwrt,
*active = reg; *active = reg;
if (le32_to_cpu(reg->region_type) != if (type == IWL_FW_INI_REGION_TXF ||
IWL_FW_INI_REGION_DRAM_BUFFER) type == IWL_FW_INI_REGION_RXF)
iter += le32_to_cpu(reg->num_of_ranges) * iter += le32_to_cpu(reg->fifos.num_of_registers) *
sizeof(__le32);
else if (type != IWL_FW_INI_REGION_DRAM_BUFFER)
iter += le32_to_cpu(reg->internal.num_of_ranges) *
sizeof(__le32); sizeof(__le32);
iter += sizeof(*reg); iter += sizeof(*reg);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment