ath10k: make target endianess more explicit
Some copy engine structures are target specific and are uploaded to the device during init/configuration. This also cleans up a bit diag_mem_read/write implicit byteswap mess leaving only diag_access_read/write with an implicit endianess byteswap. Signed-off-by: Michal Kazior <michal.kazior@tieto.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
This commit is contained in:
parent
7c6aa25db4
commit
0fdc14e42b
@ -149,74 +149,74 @@ static const struct ce_attr host_ce_config_wlan[] = {
|
|||||||
static const struct ce_pipe_config target_ce_config_wlan[] = {
|
static const struct ce_pipe_config target_ce_config_wlan[] = {
|
||||||
/* CE0: host->target HTC control and raw streams */
|
/* CE0: host->target HTC control and raw streams */
|
||||||
{
|
{
|
||||||
.pipenum = 0,
|
.pipenum = __cpu_to_le32(0),
|
||||||
.pipedir = PIPEDIR_OUT,
|
.pipedir = __cpu_to_le32(PIPEDIR_OUT),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 256,
|
.nbytes_max = __cpu_to_le32(256),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE1: target->host HTT + HTC control */
|
/* CE1: target->host HTT + HTC control */
|
||||||
{
|
{
|
||||||
.pipenum = 1,
|
.pipenum = __cpu_to_le32(1),
|
||||||
.pipedir = PIPEDIR_IN,
|
.pipedir = __cpu_to_le32(PIPEDIR_IN),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 512,
|
.nbytes_max = __cpu_to_le32(512),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE2: target->host WMI */
|
/* CE2: target->host WMI */
|
||||||
{
|
{
|
||||||
.pipenum = 2,
|
.pipenum = __cpu_to_le32(2),
|
||||||
.pipedir = PIPEDIR_IN,
|
.pipedir = __cpu_to_le32(PIPEDIR_IN),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 2048,
|
.nbytes_max = __cpu_to_le32(2048),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE3: host->target WMI */
|
/* CE3: host->target WMI */
|
||||||
{
|
{
|
||||||
.pipenum = 3,
|
.pipenum = __cpu_to_le32(3),
|
||||||
.pipedir = PIPEDIR_OUT,
|
.pipedir = __cpu_to_le32(PIPEDIR_OUT),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 2048,
|
.nbytes_max = __cpu_to_le32(2048),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE4: host->target HTT */
|
/* CE4: host->target HTT */
|
||||||
{
|
{
|
||||||
.pipenum = 4,
|
.pipenum = __cpu_to_le32(4),
|
||||||
.pipedir = PIPEDIR_OUT,
|
.pipedir = __cpu_to_le32(PIPEDIR_OUT),
|
||||||
.nentries = 256,
|
.nentries = __cpu_to_le32(256),
|
||||||
.nbytes_max = 256,
|
.nbytes_max = __cpu_to_le32(256),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* NB: 50% of src nentries, since tx has 2 frags */
|
/* NB: 50% of src nentries, since tx has 2 frags */
|
||||||
|
|
||||||
/* CE5: unused */
|
/* CE5: unused */
|
||||||
{
|
{
|
||||||
.pipenum = 5,
|
.pipenum = __cpu_to_le32(5),
|
||||||
.pipedir = PIPEDIR_OUT,
|
.pipedir = __cpu_to_le32(PIPEDIR_OUT),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 2048,
|
.nbytes_max = __cpu_to_le32(2048),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE6: Reserved for target autonomous hif_memcpy */
|
/* CE6: Reserved for target autonomous hif_memcpy */
|
||||||
{
|
{
|
||||||
.pipenum = 6,
|
.pipenum = __cpu_to_le32(6),
|
||||||
.pipedir = PIPEDIR_INOUT,
|
.pipedir = __cpu_to_le32(PIPEDIR_INOUT),
|
||||||
.nentries = 32,
|
.nentries = __cpu_to_le32(32),
|
||||||
.nbytes_max = 4096,
|
.nbytes_max = __cpu_to_le32(4096),
|
||||||
.flags = CE_ATTR_FLAGS,
|
.flags = __cpu_to_le32(CE_ATTR_FLAGS),
|
||||||
.reserved = 0,
|
.reserved = __cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
|
|
||||||
/* CE7 used only by Host */
|
/* CE7 used only by Host */
|
||||||
@ -229,92 +229,92 @@ static const struct ce_pipe_config target_ce_config_wlan[] = {
|
|||||||
*/
|
*/
|
||||||
static const struct service_to_pipe target_service_to_ce_map_wlan[] = {
|
static const struct service_to_pipe target_service_to_ce_map_wlan[] = {
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_VO,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_VO),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
3,
|
__cpu_to_le32(3),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_VO,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_VO),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
2,
|
__cpu_to_le32(2),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_BK,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_BK),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
3,
|
__cpu_to_le32(3),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_BK,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_BK),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
2,
|
__cpu_to_le32(2),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_BE,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_BE),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
3,
|
__cpu_to_le32(3),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_BE,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_BE),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
2,
|
__cpu_to_le32(2),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_VI,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_VI),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
3,
|
__cpu_to_le32(3),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_DATA_VI,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_DATA_VI),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
2,
|
__cpu_to_le32(2),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_CONTROL,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_CONTROL),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
3,
|
__cpu_to_le32(3),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_WMI_CONTROL,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_WMI_CONTROL),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
2,
|
__cpu_to_le32(2),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_RSVD_CTRL,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_RSVD_CTRL),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
0, /* could be moved to 3 (share with WMI) */
|
__cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_RSVD_CTRL,
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_RSVD_CTRL),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
1,
|
__cpu_to_le32(1),
|
||||||
|
},
|
||||||
|
{ /* not used */
|
||||||
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_TEST_RAW_STREAMS),
|
||||||
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
|
__cpu_to_le32(0),
|
||||||
|
},
|
||||||
|
{ /* not used */
|
||||||
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_TEST_RAW_STREAMS),
|
||||||
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
|
__cpu_to_le32(1),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_TEST_RAW_STREAMS, /* not currently used */
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_HTT_DATA_MSG),
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
__cpu_to_le32(PIPEDIR_OUT), /* out = UL = host -> target */
|
||||||
0,
|
__cpu_to_le32(4),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
ATH10K_HTC_SVC_ID_TEST_RAW_STREAMS, /* not currently used */
|
__cpu_to_le32(ATH10K_HTC_SVC_ID_HTT_DATA_MSG),
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
__cpu_to_le32(PIPEDIR_IN), /* in = DL = target -> host */
|
||||||
1,
|
__cpu_to_le32(1),
|
||||||
},
|
|
||||||
{
|
|
||||||
ATH10K_HTC_SVC_ID_HTT_DATA_MSG,
|
|
||||||
PIPEDIR_OUT, /* out = UL = host -> target */
|
|
||||||
4,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ATH10K_HTC_SVC_ID_HTT_DATA_MSG,
|
|
||||||
PIPEDIR_IN, /* in = DL = target -> host */
|
|
||||||
1,
|
|
||||||
},
|
},
|
||||||
|
|
||||||
/* (Additions here) */
|
/* (Additions here) */
|
||||||
|
|
||||||
{ /* Must be last */
|
{ /* must be last */
|
||||||
0,
|
__cpu_to_le32(0),
|
||||||
0,
|
__cpu_to_le32(0),
|
||||||
0,
|
__cpu_to_le32(0),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -602,14 +602,9 @@ static int ath10k_pci_diag_read_mem(struct ath10k *ar, u32 address, void *data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
done:
|
done:
|
||||||
if (ret == 0) {
|
if (ret == 0)
|
||||||
/* Copy data from allocated DMA buf to caller's buf */
|
memcpy(data, data_buf, orig_nbytes);
|
||||||
WARN_ON_ONCE(orig_nbytes & 3);
|
else
|
||||||
for (i = 0; i < orig_nbytes / sizeof(__le32); i++) {
|
|
||||||
((u32 *)data)[i] =
|
|
||||||
__le32_to_cpu(((__le32 *)data_buf)[i]);
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
ath10k_warn(ar, "failed to read diag value at 0x%x: %d\n",
|
ath10k_warn(ar, "failed to read diag value at 0x%x: %d\n",
|
||||||
address, ret);
|
address, ret);
|
||||||
|
|
||||||
@ -622,7 +617,13 @@ done:
|
|||||||
|
|
||||||
static int ath10k_pci_diag_read32(struct ath10k *ar, u32 address, u32 *value)
|
static int ath10k_pci_diag_read32(struct ath10k *ar, u32 address, u32 *value)
|
||||||
{
|
{
|
||||||
return ath10k_pci_diag_read_mem(ar, address, value, sizeof(u32));
|
__le32 val = 0;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = ath10k_pci_diag_read_mem(ar, address, &val, sizeof(val));
|
||||||
|
*value = __le32_to_cpu(val);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __ath10k_pci_diag_read_hi(struct ath10k *ar, void *dest,
|
static int __ath10k_pci_diag_read_hi(struct ath10k *ar, void *dest,
|
||||||
@ -699,9 +700,7 @@ static int ath10k_pci_diag_write_mem(struct ath10k *ar, u32 address,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Copy caller's data to allocated DMA buf */
|
/* Copy caller's data to allocated DMA buf */
|
||||||
WARN_ON_ONCE(orig_nbytes & 3);
|
memcpy(data_buf, data, orig_nbytes);
|
||||||
for (i = 0; i < orig_nbytes / sizeof(__le32); i++)
|
|
||||||
((__le32 *)data_buf)[i] = __cpu_to_le32(((u32 *)data)[i]);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The address supplied by the caller is in the
|
* The address supplied by the caller is in the
|
||||||
@ -797,14 +796,20 @@ done:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ath10k_pci_diag_write32(struct ath10k *ar, u32 address, u32 value)
|
||||||
|
{
|
||||||
|
__le32 val = __cpu_to_le32(value);
|
||||||
|
|
||||||
|
return ath10k_pci_diag_write_mem(ar, address, &val, sizeof(val));
|
||||||
|
}
|
||||||
|
|
||||||
/* Write 4B data to Target memory or register */
|
/* Write 4B data to Target memory or register */
|
||||||
static int ath10k_pci_diag_write_access(struct ath10k *ar, u32 address,
|
static int ath10k_pci_diag_write_access(struct ath10k *ar, u32 address,
|
||||||
u32 data)
|
u32 data)
|
||||||
{
|
{
|
||||||
/* Assume range doesn't cross this boundary */
|
/* Assume range doesn't cross this boundary */
|
||||||
if (address >= DRAM_BASE_ADDRESS)
|
if (address >= DRAM_BASE_ADDRESS)
|
||||||
return ath10k_pci_diag_write_mem(ar, address, &data,
|
return ath10k_pci_diag_write32(ar, address, data);
|
||||||
sizeof(u32));
|
|
||||||
|
|
||||||
ath10k_pci_write32(ar, address, data);
|
ath10k_pci_write32(ar, address, data);
|
||||||
return 0;
|
return 0;
|
||||||
@ -988,14 +993,14 @@ static u16 ath10k_pci_hif_get_free_queue_number(struct ath10k *ar, u8 pipe)
|
|||||||
static void ath10k_pci_dump_registers(struct ath10k *ar,
|
static void ath10k_pci_dump_registers(struct ath10k *ar,
|
||||||
struct ath10k_fw_crash_data *crash_data)
|
struct ath10k_fw_crash_data *crash_data)
|
||||||
{
|
{
|
||||||
u32 i, reg_dump_values[REG_DUMP_COUNT_QCA988X] = {};
|
__le32 reg_dump_values[REG_DUMP_COUNT_QCA988X] = {};
|
||||||
int ret;
|
int i, ret;
|
||||||
|
|
||||||
lockdep_assert_held(&ar->data_lock);
|
lockdep_assert_held(&ar->data_lock);
|
||||||
|
|
||||||
ret = ath10k_pci_diag_read_hi(ar, ®_dump_values[0],
|
ret = ath10k_pci_diag_read_hi(ar, ®_dump_values[0],
|
||||||
hi_failure_state,
|
hi_failure_state,
|
||||||
REG_DUMP_COUNT_QCA988X * sizeof(u32));
|
REG_DUMP_COUNT_QCA988X * sizeof(__le32));
|
||||||
if (ret) {
|
if (ret) {
|
||||||
ath10k_err(ar, "failed to read firmware dump area: %d\n", ret);
|
ath10k_err(ar, "failed to read firmware dump area: %d\n", ret);
|
||||||
return;
|
return;
|
||||||
@ -1007,17 +1012,16 @@ static void ath10k_pci_dump_registers(struct ath10k *ar,
|
|||||||
for (i = 0; i < REG_DUMP_COUNT_QCA988X; i += 4)
|
for (i = 0; i < REG_DUMP_COUNT_QCA988X; i += 4)
|
||||||
ath10k_err(ar, "[%02d]: 0x%08X 0x%08X 0x%08X 0x%08X\n",
|
ath10k_err(ar, "[%02d]: 0x%08X 0x%08X 0x%08X 0x%08X\n",
|
||||||
i,
|
i,
|
||||||
reg_dump_values[i],
|
__le32_to_cpu(reg_dump_values[i]),
|
||||||
reg_dump_values[i + 1],
|
__le32_to_cpu(reg_dump_values[i + 1]),
|
||||||
reg_dump_values[i + 2],
|
__le32_to_cpu(reg_dump_values[i + 2]),
|
||||||
reg_dump_values[i + 3]);
|
__le32_to_cpu(reg_dump_values[i + 3]));
|
||||||
|
|
||||||
if (!crash_data)
|
if (!crash_data)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* crash_data is in little endian */
|
|
||||||
for (i = 0; i < REG_DUMP_COUNT_QCA988X; i++)
|
for (i = 0; i < REG_DUMP_COUNT_QCA988X; i++)
|
||||||
crash_data->registers[i] = cpu_to_le32(reg_dump_values[i]);
|
crash_data->registers[i] = reg_dump_values[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ath10k_pci_fw_crashed_dump(struct ath10k *ar)
|
static void ath10k_pci_fw_crashed_dump(struct ath10k *ar)
|
||||||
@ -1111,27 +1115,27 @@ static int ath10k_pci_hif_map_service_to_pipe(struct ath10k *ar,
|
|||||||
for (i = 0; i < ARRAY_SIZE(target_service_to_ce_map_wlan); i++) {
|
for (i = 0; i < ARRAY_SIZE(target_service_to_ce_map_wlan); i++) {
|
||||||
entry = &target_service_to_ce_map_wlan[i];
|
entry = &target_service_to_ce_map_wlan[i];
|
||||||
|
|
||||||
if (entry->service_id != service_id)
|
if (__le32_to_cpu(entry->service_id) != service_id)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
switch (entry->pipedir) {
|
switch (__le32_to_cpu(entry->pipedir)) {
|
||||||
case PIPEDIR_NONE:
|
case PIPEDIR_NONE:
|
||||||
break;
|
break;
|
||||||
case PIPEDIR_IN:
|
case PIPEDIR_IN:
|
||||||
WARN_ON(dl_set);
|
WARN_ON(dl_set);
|
||||||
*dl_pipe = entry->pipenum;
|
*dl_pipe = __le32_to_cpu(entry->pipenum);
|
||||||
dl_set = true;
|
dl_set = true;
|
||||||
break;
|
break;
|
||||||
case PIPEDIR_OUT:
|
case PIPEDIR_OUT:
|
||||||
WARN_ON(ul_set);
|
WARN_ON(ul_set);
|
||||||
*ul_pipe = entry->pipenum;
|
*ul_pipe = __le32_to_cpu(entry->pipenum);
|
||||||
ul_set = true;
|
ul_set = true;
|
||||||
break;
|
break;
|
||||||
case PIPEDIR_INOUT:
|
case PIPEDIR_INOUT:
|
||||||
WARN_ON(dl_set);
|
WARN_ON(dl_set);
|
||||||
WARN_ON(ul_set);
|
WARN_ON(ul_set);
|
||||||
*dl_pipe = entry->pipenum;
|
*dl_pipe = __le32_to_cpu(entry->pipenum);
|
||||||
*ul_pipe = entry->pipenum;
|
*ul_pipe = __le32_to_cpu(entry->pipenum);
|
||||||
dl_set = true;
|
dl_set = true;
|
||||||
ul_set = true;
|
ul_set = true;
|
||||||
break;
|
break;
|
||||||
@ -1583,10 +1587,9 @@ static int ath10k_pci_init_config(struct ath10k *ar)
|
|||||||
|
|
||||||
pcie_config_flags &= ~PCIE_CONFIG_FLAG_ENABLE_L1;
|
pcie_config_flags &= ~PCIE_CONFIG_FLAG_ENABLE_L1;
|
||||||
|
|
||||||
ret = ath10k_pci_diag_write_mem(ar, pcie_state_targ_addr +
|
ret = ath10k_pci_diag_write_access(ar, pcie_state_targ_addr +
|
||||||
offsetof(struct pcie_state, config_flags),
|
offsetof(struct pcie_state, config_flags),
|
||||||
&pcie_config_flags,
|
pcie_config_flags);
|
||||||
sizeof(pcie_config_flags));
|
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
ath10k_err(ar, "Failed to write pcie config_flags: %d\n", ret);
|
ath10k_err(ar, "Failed to write pcie config_flags: %d\n", ret);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -100,12 +100,12 @@ struct pcie_state {
|
|||||||
* NOTE: Structure is shared between Host software and Target firmware!
|
* NOTE: Structure is shared between Host software and Target firmware!
|
||||||
*/
|
*/
|
||||||
struct ce_pipe_config {
|
struct ce_pipe_config {
|
||||||
u32 pipenum;
|
__le32 pipenum;
|
||||||
u32 pipedir;
|
__le32 pipedir;
|
||||||
u32 nentries;
|
__le32 nentries;
|
||||||
u32 nbytes_max;
|
__le32 nbytes_max;
|
||||||
u32 flags;
|
__le32 flags;
|
||||||
u32 reserved;
|
__le32 reserved;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -127,9 +127,9 @@ struct ce_pipe_config {
|
|||||||
|
|
||||||
/* Establish a mapping between a service/direction and a pipe. */
|
/* Establish a mapping between a service/direction and a pipe. */
|
||||||
struct service_to_pipe {
|
struct service_to_pipe {
|
||||||
u32 service_id;
|
__le32 service_id;
|
||||||
u32 pipedir;
|
__le32 pipedir;
|
||||||
u32 pipenum;
|
__le32 pipenum;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Per-pipe state. */
|
/* Per-pipe state. */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user