[alsa-devel] [PATCH 09/12] drm/amd: remove bitfield usage in ACP IP module
Alex Deucher
alexdeucher at gmail.com
Thu Aug 6 16:25:09 CEST 2015
From: Maruthi Srinivas Bayyavarapu <Maruthi.Bayyavarapu at amd.com>
Replaced usage of bitfield logic with alternative
Signed-off-by: Maruthi Bayyavarapu <maruthi.bayyavarapu at amd.com>
Reviewed- by: Alex Deucher <alexander.deucher at amd.com>
---
drivers/gpu/drm/amd/acp/acp_hw.c | 61 +++++++++++++++++-----------------------
drivers/gpu/drm/amd/acp/acp_hw.h | 22 +--------------
2 files changed, 27 insertions(+), 56 deletions(-)
diff --git a/drivers/gpu/drm/amd/acp/acp_hw.c b/drivers/gpu/drm/amd/acp/acp_hw.c
index 7ee2aa6..744d908 100644
--- a/drivers/gpu/drm/amd/acp/acp_hw.c
+++ b/drivers/gpu/drm/amd/acp/acp_hw.c
@@ -131,7 +131,7 @@ static void config_dma_descriptor_in_sram(struct amd_acp_device *acp_dev,
cgs_write_register(acp_prv->cgs_device, mmACP_SRBM_Targ_Idx_Addr,
(sram_offset + 8));
cgs_write_register(acp_prv->cgs_device, mmACP_SRBM_Targ_Idx_Data,
- descr_info->size_xfer_dir.val);
+ descr_info->xfer_val);
}
/* Initialize the DMA descriptor information for transfer between
@@ -147,48 +147,44 @@ static void set_acp_sysmem_dma_descriptors(struct amd_acp_device *acp_dev,
num_descr = 2;
- dmadscr[0].size_xfer_dir.val = (u32) 0x0;
+ dmadscr[0].xfer_val = 0;
if (direction == STREAM_PLAYBACK) {
dma_dscr_idx = PLAYBACK_START_DMA_DESCR_CH12;
dmadscr[0].dest = ACP_SHARED_RAM_BANK_1_ADDRESS + (size / 2);
dmadscr[0].src = ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS +
(pte_offset * PAGE_SIZE_4K);
- dmadscr[0].size_xfer_dir.s.trans_direction =
- ACP_DMA_ATTRIBUTES_DAGB_ONION_TO_SHAREDMEM;
- dmadscr[0].size_xfer_dir.s.size = (size / 2);
- dmadscr[0].size_xfer_dir.s.ioc = (u32) 0x0;
+ dmadscr[0].xfer_val |= (DISABLE << 22) |
+ (ACP_DMA_ATTRIBUTES_DAGB_ONION_TO_SHAREDMEM << 16) |
+ (size / 2);
} else {
dma_dscr_idx = CAPTURE_START_DMA_DESCR_CH14;
dmadscr[0].src = ACP_SHARED_RAM_BANK_5_ADDRESS;
dmadscr[0].dest = ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS +
(pte_offset * PAGE_SIZE_4K);
- dmadscr[0].size_xfer_dir.s.trans_direction =
- ACP_DMA_ATTRIBUTES_SHAREDMEM_TO_DAGB_ONION;
- dmadscr[0].size_xfer_dir.s.size = size / 2;
- dmadscr[0].size_xfer_dir.s.ioc = (u32) 0x1;
+ dmadscr[0].xfer_val |=
+ (ENABLE << 22) |
+ (ACP_DMA_ATTRIBUTES_SHAREDMEM_TO_DAGB_ONION << 16) |
+ (size / 2);
}
config_dma_descriptor_in_sram(acp_dev, dma_dscr_idx, &dmadscr[0]);
- dmadscr[1].size_xfer_dir.val = (u32) 0x0;
+ dmadscr[1].xfer_val = 0;
if (direction == STREAM_PLAYBACK) {
dma_dscr_idx = PLAYBACK_END_DMA_DESCR_CH12;
dmadscr[1].dest = ACP_SHARED_RAM_BANK_1_ADDRESS;
dmadscr[1].src = ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS +
(pte_offset * PAGE_SIZE_4K) + (size / 2);
- dmadscr[1].size_xfer_dir.s.trans_direction =
- ACP_DMA_ATTRIBUTES_DAGB_ONION_TO_SHAREDMEM;
- dmadscr[1].size_xfer_dir.s.size = (size / 2);
- dmadscr[1].size_xfer_dir.s.ioc = (u32) 0x0;
+ dmadscr[1].xfer_val |= (DISABLE << 22) |
+ (ACP_DMA_ATTRIBUTES_DAGB_ONION_TO_SHAREDMEM << 16) |
+ (size / 2);
} else {
dma_dscr_idx = CAPTURE_END_DMA_DESCR_CH14;
- dmadscr[1].size_xfer_dir.s.trans_direction =
- ACP_DMA_ATTRIBUTES_SHAREDMEM_TO_DAGB_ONION;
- dmadscr[1].size_xfer_dir.val = (u32) 0x0;
dmadscr[1].dest = dmadscr[0].dest + (size / 2);
dmadscr[1].src = dmadscr[0].src + (size / 2);
- dmadscr[1].size_xfer_dir.s.size = (size / 2);
- dmadscr[1].size_xfer_dir.s.ioc = (u32) 0x1;
+ dmadscr[1].xfer_val |= (ENABLE << 22) |
+ (ACP_DMA_ATTRIBUTES_SHAREDMEM_TO_DAGB_ONION << 16) |
+ (size / 2);
}
config_dma_descriptor_in_sram(acp_dev, dma_dscr_idx, &dmadscr[1]);
@@ -221,37 +217,32 @@ static void set_acp_to_i2s_dma_descriptors(struct amd_acp_device *acp_dev,
num_descr = 2;
- dmadscr[0].size_xfer_dir.val = (u32) 0x0;
+ dmadscr[0].xfer_val = 0;
if (direction == STREAM_PLAYBACK) {
dma_dscr_idx = PLAYBACK_START_DMA_DESCR_CH13;
dmadscr[0].src = ACP_SHARED_RAM_BANK_1_ADDRESS;
- dmadscr[0].size_xfer_dir.s.trans_direction = TO_ACP_I2S_1;
- dmadscr[0].size_xfer_dir.s.size = (size / 2);
- dmadscr[0].size_xfer_dir.s.ioc = (u32) 0x1;
+ dmadscr[0].xfer_val |= (ENABLE << 22) | (TO_ACP_I2S_1 << 16) |
+ (size / 2);
} else {
dma_dscr_idx = CAPTURE_START_DMA_DESCR_CH15;
dmadscr[0].dest = ACP_SHARED_RAM_BANK_5_ADDRESS;
- dmadscr[0].size_xfer_dir.s.trans_direction = FROM_ACP_I2S_1;
- dmadscr[0].size_xfer_dir.s.size = (size / 2);
- dmadscr[0].size_xfer_dir.s.ioc = (u32) 0x1;
+ dmadscr[0].xfer_val |= (ENABLE << 22) |
+ (FROM_ACP_I2S_1 << 16) | (size / 2);
}
config_dma_descriptor_in_sram(acp_dev, dma_dscr_idx, &dmadscr[0]);
- dmadscr[1].size_xfer_dir.val = (u32) 0x0;
+ dmadscr[1].xfer_val = 0;
if (direction == STREAM_PLAYBACK) {
dma_dscr_idx = PLAYBACK_END_DMA_DESCR_CH13;
dmadscr[1].src = dmadscr[0].src + (size / 2);
- dmadscr[1].size_xfer_dir.s.trans_direction = TO_ACP_I2S_1;
- dmadscr[1].size_xfer_dir.s.size = (size / 2);
- dmadscr[1].size_xfer_dir.s.ioc = (u32) 0x1;
-
+ dmadscr[1].xfer_val |= (ENABLE << 22) | (TO_ACP_I2S_1 << 16) |
+ (size / 2);
} else {
dma_dscr_idx = CAPTURE_END_DMA_DESCR_CH15;
dmadscr[1].dest = dmadscr[0].dest + (size / 2);
- dmadscr[1].size_xfer_dir.s.trans_direction = FROM_ACP_I2S_1;
- dmadscr[1].size_xfer_dir.s.size = (size / 2);
- dmadscr[1].size_xfer_dir.s.ioc = (u32) 0x1;
+ dmadscr[1].xfer_val |= (ENABLE << 22) |
+ (FROM_ACP_I2S_1 << 16) | (size / 2);
}
config_dma_descriptor_in_sram(acp_dev, dma_dscr_idx, &dmadscr[1]);
diff --git a/drivers/gpu/drm/amd/acp/acp_hw.h b/drivers/gpu/drm/amd/acp/acp_hw.h
index b58349c..e3a102c 100644
--- a/drivers/gpu/drm/amd/acp/acp_hw.h
+++ b/drivers/gpu/drm/amd/acp/acp_hw.h
@@ -73,26 +73,6 @@ enum {
ACP_DMA_ATTRIBUTES_FORCE_SIZE = 0xF
};
-typedef struct acp_dma_dscr_size_transfer_direction {
- /* Specifies the number of bytes need to be transferred
- * from source to destination memory. */
- u32 size:16;
- /* Specifies transfer direction. */
- u32 trans_direction:4;
- /* reserved. */
- u32 reserved1:2;
- /* Specifies the IOC enable or not for descriptor. */
- /* Defaultly this will be 0, for the last descriptor, make it Enable */
- u32 ioc:1;
- /* reserved. */
- u32 reserved2:9;
-} acp_dma_dscr_size_transfer_direction_t;
-
-typedef union {
- u32 val:32;
- acp_dma_dscr_size_transfer_direction_t s;
-} acp_dma_dscr_size_transfer_direction_u;
-
typedef struct acp_dma_dscr_transfer {
/* Specifies the source memory location for the DMA data transfer. */
u32 src;
@@ -103,7 +83,7 @@ typedef struct acp_dma_dscr_transfer {
/* Specifies the number of bytes need to be transferred
* from source to destination memory.Transfer direction & IOC enable
*/
- acp_dma_dscr_size_transfer_direction_u size_xfer_dir;
+ u32 xfer_val;
/** Reserved for future use */
u32 reserved;
} acp_dma_dscr_transfer_t;
--
1.8.3.1
More information about the Alsa-devel
mailing list