Server IP : 13.213.54.232 / Your IP : 216.73.216.72 Web Server : Apache/2.4.52 (Ubuntu) System : Linux ip-172-31-17-110 6.8.0-1029-aws #31~22.04.1-Ubuntu SMP Thu Apr 24 21:16:18 UTC 2025 x86_64 User : www-data ( 33) PHP Version : 7.1.33-67+ubuntu22.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/lib/modules/6.8.0-1029-aws/build/include/linux/dma/ |
Upload File : |
/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (c) 2016-2017, The Linux Foundation. All rights reserved. */ #ifndef _QCOM_BAM_DMA_H #define _QCOM_BAM_DMA_H #include <asm/byteorder.h> /* * This data type corresponds to the native Command Element * supported by BAM DMA Engine. * * @cmd_and_addr - upper 8 bits command and lower 24 bits register address. * @data - for write command: content to be written into peripheral register. * for read command: dest addr to write peripheral register value. * @mask - register mask. * @reserved - for future usage. * */ struct bam_cmd_element { __le32 cmd_and_addr; __le32 data; __le32 mask; __le32 reserved; }; /* * This enum indicates the command type in a command element */ enum bam_command_type { BAM_WRITE_COMMAND = 0, BAM_READ_COMMAND, }; /* * prep_bam_ce_le32 - Wrapper function to prepare a single BAM command * element with the data already in le32 format. * * @bam_ce: bam command element * @addr: target address * @cmd: BAM command * @data: actual data for write and dest addr for read in le32 */ static inline void bam_prep_ce_le32(struct bam_cmd_element *bam_ce, u32 addr, enum bam_command_type cmd, __le32 data) { bam_ce->cmd_and_addr = cpu_to_le32((addr & 0xffffff) | ((cmd & 0xff) << 24)); bam_ce->data = data; bam_ce->mask = cpu_to_le32(0xffffffff); } /* * bam_prep_ce - Wrapper function to prepare a single BAM command element * with the data. * * @bam_ce: BAM command element * @addr: target address * @cmd: BAM command * @data: actual data for write and dest addr for read */ static inline void bam_prep_ce(struct bam_cmd_element *bam_ce, u32 addr, enum bam_command_type cmd, u32 data) { bam_prep_ce_le32(bam_ce, addr, cmd, cpu_to_le32(data)); } #endif