|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 7 B7 k8 a7 ], v5 ~: j
- [code]EDMA sample test application; u/ E* L9 w7 O0 b+ l
- /*0 y# R1 x @; r% N9 O$ V/ S+ v
- * edma_test.c
: g4 Y! p; n# Q1 W( R - *9 p i- f9 q5 S1 g" b, G5 T
- * brief EDMA3 Test Application
8 _4 m2 {" Z0 k - * }2 F# y7 \, ?, X6 ^, o" y
- * This file contains EDMA3 Test code.
, t' ?9 S5 C. E% M - *& u2 Y( Y; J& d7 T" `1 I9 ~
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE g0 d; r8 M/ K
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT. G3 O& m# S. w4 n9 Q; M
- * TO CHANGE.
k4 ` x% ?+ ?& r$ _6 O5 N - *
. T* _% u+ O* D) f+ g7 m8 ` - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
9 i0 o6 d7 Y" O9 A8 Q - *
8 d( f1 _0 Z$ k4 L/ } K$ k& T6 N - * This program is free software; you can redistribute it and/or' j( K& D9 K- C" w6 Q9 M; l9 C
- * modify it under the terms of the GNU General Public License as- C2 _- q: @8 @0 k7 c
- * published by the Free Software Foundation version 2.
; A" r2 `( l! @" a/ O, f. ?0 i - *
5 j( C; n9 j6 a ~" @4 v - * This program is distributed "as is" WITHOUT ANY WARRANTY of any
Z% H/ W1 y! l, a5 ? - * kind, whether express or implied; without even the implied warranty" O! I# }! y) t+ F! ~/ u! \
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
" P" X; Y$ Y1 t, M0 s2 _ - * GNU General Public License for more details.
$ ?6 B% H4 h. a0 M( j- A7 L) b - */
6 F7 N! r2 g! v- L9 ~
& G/ h7 j6 ]5 p% \3 J- #include <linux/module.h>& |# R" f( Z& }9 N1 O. O" ^
- #include <linux/init.h>* e* j; b# K) v( U# s# `
- #include <linux/errno.h>& D1 u2 ]* X) Z! _
- #include <linux/types.h>1 U( j/ }9 [7 q9 ?. K
- #include <linux/interrupt.h>
$ k! o8 ?9 p! B6 V9 U3 _( u - #include <asm/io.h>
6 O. O/ d7 v0 D5 v' L- g0 ] - #include <linux/moduleparam.h>8 ^6 p: ~; m7 U+ j9 E/ d8 A
- #include <linux/sysctl.h># y" M2 W/ Y% D9 K- I5 K$ \
- #include <linux/mm.h>& E& u5 i; W. k: ~
- #include <linux/dma-mapping.h>4 W5 T! n4 l# u% K! y% V
4 x* w* a7 J% \8 ?1 M9 J/ B- b- #include <mach/memory.h>
& v: M3 V0 I W* i, q% G4 w - #include <mach/hardware.h>
+ N1 [% g& L7 D% i, P, D. ] - #include <mach/irqs.h>
" w. ]9 p/ H+ K1 u - #include <asm/hardware/edma.h>
5 q5 o" \* o. U+ o& s) B1 Q: h, Z - Y: M2 p0 W0 T$ U# j* |4 J. f; w
- #undef EDMA3_DEBUG
. d* ~6 R( t' J' z! g - /*#define EDMA3_DEBUG*/1 H' O+ v: s, o) g# O: g' X( l
, [6 r4 r& ~" J0 q+ F6 c3 A q- #ifdef EDMA3_DEBUG
$ Z) D, {9 n8 ^+ K* |9 m) v - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
% t0 F' m" F4 F: m# a - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)% L: l) c* W0 D6 g( U
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
0 S' i: C# v9 F- V - #else
2 N+ @4 g2 V$ ^) F" f% l |) B - #define DMA_PRINTK( x... ); `# G& S0 ?, B# l1 b( z( [( Y
- #define DMA_FN_IN6 `$ e' X* Q6 G% P9 o' B
- #define DMA_FN_OUT
8 Z, d- v6 K n6 Y6 M( p# L - #endif4 S6 E* @' A5 b3 o0 b/ W% A: K
1 X, d2 ~( `4 J5 C" Q, l; w- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
0 L8 e/ G- R' Z - #define STATIC_SHIFT 3
: x' a3 a; [3 x n7 e - #define TCINTEN_SHIFT 201 `, ?( o$ g0 h7 i9 M' Z- p
- #define ITCINTEN_SHIFT 21
, C" R, {7 N" W - #define TCCHEN_SHIFT 22' J, t- Q. ?: H k* N) _
- #define ITCCHEN_SHIFT 23
% {* J7 P5 }) c: J7 C$ L7 W
3 P; C- i# y0 a5 Z- static volatile int irqraised1 = 0;
4 U/ q. T3 p7 M2 t) [ - static volatile int irqraised2 = 0;- C! R4 }4 C* s6 V
- ( @' s; M+ S4 h% d
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
; A7 U' a3 @+ q; }7 e - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);" u& E8 b( t& {5 g
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);% H- v0 r' _0 V, _- X
- / N! U, L1 S- c8 _1 N
- dma_addr_t dmaphyssrc1 = 0;, e7 \( q$ a8 H* w8 o" ^
- dma_addr_t dmaphyssrc2 = 0;* D2 A2 Q% p5 x. N" U3 y4 c
- dma_addr_t dmaphysdest1 = 0;
' E* u6 L' ~, u9 e$ G4 T/ d9 k$ S - dma_addr_t dmaphysdest2 = 0;1 J) S$ m) z$ I6 w
- q2 [' J0 O! D7 R& t
- char *dmabufsrc1 = NULL;& U9 f2 c: J( A% T
- char *dmabufsrc2 = NULL; f/ F& O" S1 w' D1 y7 e- h
- char *dmabufdest1 = NULL;8 @# S) j% z! x% | z
- char *dmabufdest2 = NULL;) F( n$ r& h4 f2 F2 O
- 5 O1 x1 @; M6 [7 E
- static int acnt = 512;, [. d4 k1 j, |5 f
- static int bcnt = 8;
+ F% m. l4 G5 F) E! f5 R4 [ - static int ccnt = 8;: k) R6 e. m( Q
( G7 _8 d- c# A: `* J- module_param(acnt, int, S_IRUGO);
" _9 N- `8 l1 e( w - module_param(bcnt, int, S_IRUGO);3 i. U* o6 `6 \% ?+ `
- module_param(ccnt, int, S_IRUGO);
复制代码 ' e$ z6 g q2 }- h& F
" [5 B% L; t5 l+ z1 C
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用' O1 G+ }% }* J% Z
arm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
0 }7 r8 `8 I# \ 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
3 {9 X4 b4 }& G8 G3 q3 j, u1 k
" w; K2 @; H/ ?- ]+ w4 {
' R ?2 D8 C0 Q |
|