|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 6 \# F# X' A* M* ?( b
- [code]EDMA sample test application" i1 V- E/ g/ J7 q
- /*/ _, {2 `2 @& ]/ m3 A5 x( R7 {( H
- * edma_test.c
: Y# s P$ }1 J* J' | - *# g/ l) |1 V B
- * brief EDMA3 Test Application
% d! x& f+ G- M% u7 h# L; D - *( d* I3 P1 w* G
- * This file contains EDMA3 Test code.
( _$ I5 _1 A- T4 g# A! s( p" q5 A - *
" W, w9 Q/ O1 X) ~( ?2 [ - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
- b9 c/ g; P. Z- k - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT- N0 B- W8 p9 l$ G, C
- * TO CHANGE.
4 e2 @, x1 p. _1 M6 } - *
! ^) v: v I! Q. B6 j. N) s0 t* Q - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
# G! \: I0 F) G/ v7 c - *
* C2 @- X3 Q ^. m F - * This program is free software; you can redistribute it and/or
4 A/ M4 O+ u% k K/ _2 G - * modify it under the terms of the GNU General Public License as
. D% U; E4 U! c, ?0 M, A' G5 z - * published by the Free Software Foundation version 2.
$ |' f h- R5 l1 @& W - *' _$ Z U/ m4 _- I' T
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any/ U; `! q* e/ G/ q
- * kind, whether express or implied; without even the implied warranty
% i8 F( v+ f" E8 H( i& @ - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% _( y8 a! u% n% A$ t - * GNU General Public License for more details.
0 t- Z5 B$ z2 } ?& A6 I3 k - */5 V8 S4 T2 R( x% R. d
9 Y/ P8 o& F, e$ V2 Z5 }' I8 {- #include <linux/module.h>
" [* M3 X2 {2 Y" x; ^ - #include <linux/init.h>
5 k5 \0 |0 K5 s0 ~ - #include <linux/errno.h>
: y5 O# |- S! @7 L; ] - #include <linux/types.h>! K" p( W0 P$ l! b4 W
- #include <linux/interrupt.h>
' V# N8 K' L R - #include <asm/io.h>- s8 E# ?4 D( ^3 }$ [1 x( @
- #include <linux/moduleparam.h>3 H# `! z7 u9 L% Q. N
- #include <linux/sysctl.h>. ? D) t, j# ]) ~* \
- #include <linux/mm.h>( F- E. p) `3 t5 ^* }
- #include <linux/dma-mapping.h>
/ m+ a. D, e6 }/ k2 \# g - 3 X% f# a ]3 s7 u
- #include <mach/memory.h>: L) [6 A& d, F6 T3 ?
- #include <mach/hardware.h>
2 t: D; v* f. R' b2 i - #include <mach/irqs.h>
, m% W! x& f S5 n' z - #include <asm/hardware/edma.h>
" ]2 n( I0 ]5 U8 i
, t* X* w9 r3 d# Q! y: M- #undef EDMA3_DEBUG
# z d% o/ H7 @) I7 E - /*#define EDMA3_DEBUG*/
6 d1 J+ o- B4 x! d% L
3 s/ i$ o1 r+ M$ ~5 ] b3 F- #ifdef EDMA3_DEBUG0 Y+ {6 a8 _) u; w# i4 Q
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
$ _4 N) G3 w5 u# Q3 {; N9 K - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)9 l- D4 g! [0 b7 ~- S% h- Z
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
. F' K( S, f6 D - #else6 M I% G# [1 k' q/ g$ @! l+ C1 U
- #define DMA_PRINTK( x... )
Y+ f9 J0 R# U - #define DMA_FN_IN. x5 b3 e, D& |- F# R
- #define DMA_FN_OUT
0 [: Q) M h2 I4 ? - #endif$ q" Y" Z7 l( z- a( T" F
5 N8 p* v# A! Z2 J* A/ M1 u- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
( t# e7 p( l7 r- r$ l* p O - #define STATIC_SHIFT 3
0 x' n" A2 R+ @ - #define TCINTEN_SHIFT 20
& c1 v7 s! S$ |2 l* n: e - #define ITCINTEN_SHIFT 21+ V6 A; q$ \! j% m( Z( I$ v
- #define TCCHEN_SHIFT 22! l1 K/ K/ X- a, ]' o+ \1 o
- #define ITCCHEN_SHIFT 23
2 @) m }) \' `0 @7 d4 C% q - : O# N+ j/ p* C7 G/ C4 C
- static volatile int irqraised1 = 0;
) d4 C: z" d! ] - static volatile int irqraised2 = 0;1 ~ N( t8 ^% [" x L' j( |1 I3 t& v
- 8 m; q# E; [1 W7 |! K# J3 L9 A
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);& P* D2 e9 R1 f" }- r: w3 F) d" @
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);! `5 W6 ]( b' F0 _
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);* p2 c8 f- X1 K8 X: V
% @+ v* F2 `2 o P9 x; Y6 o% d- dma_addr_t dmaphyssrc1 = 0;- f: E/ E' e3 M/ s1 B
- dma_addr_t dmaphyssrc2 = 0;
+ `( | F! W1 a9 d$ w5 S! f - dma_addr_t dmaphysdest1 = 0;9 b6 ]$ B% ]2 U
- dma_addr_t dmaphysdest2 = 0;# d- f0 \% k; ?$ I3 \( X
2 Y) p! c8 j! O/ ^: x& Y) j7 w% ~) @) X" ?- char *dmabufsrc1 = NULL;
. H, K3 J1 ?8 r2 W, [0 I - char *dmabufsrc2 = NULL;
8 g- p$ x! z, Z9 p+ d - char *dmabufdest1 = NULL;
V9 t1 Z9 H( _' W, _% I* M& v; t - char *dmabufdest2 = NULL;! ~$ y; E0 w6 \5 C
# x4 K+ @4 I# c; j- static int acnt = 512;3 W Q- S, q% X- e
- static int bcnt = 8;
: J7 C7 t9 U& ^+ N. \- j$ ^+ y - static int ccnt = 8;
6 a+ X3 T; I: p- `0 u
0 f5 d& R: h6 p0 `8 H- module_param(acnt, int, S_IRUGO);
. V6 A8 {' c J- w; p3 N - module_param(bcnt, int, S_IRUGO);
0 @! s* Z5 v& T; O& ] - module_param(ccnt, int, S_IRUGO);
复制代码 0 a9 y! X. ^/ ^
! }, w7 k' s! [4 s6 R! ] 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
6 w/ e' X: z$ U) z& k) S6 j2 P! oarm-none-linux-gnueabi-gcc -I /home/tl/omapl138/linux-3.3/arch/arm/include -I /home/tl/omapl138/linux-3.3/include EDMA3test.cpp -o EDMA3这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。- B2 ?) O7 ~, `+ d
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
, @6 I. K: k: w+ Q9 E% y0 y! r* q# d) T7 o, z
2 A: A/ k1 R' h2 Y& J( Q
|
|