|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
( W7 W/ p( H4 \3 r- [code]EDMA sample test application5 c* r8 Z1 N$ B! D6 I( `7 K( B
- /*
# P& I: L# l# f2 M- i - * edma_test.c' x2 I! _/ W. W: G8 B$ i
- *
. d( {7 t2 {, U; `' u - * brief EDMA3 Test Application
6 R _7 y& `0 f( e# F7 u - *& q5 N1 y, U% }
- * This file contains EDMA3 Test code.
0 H( w( D- @ z% q( h - ** C) x1 l- @$ ?4 ]' Q1 Y
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE" _+ T- ]' H3 a( m
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
6 z' p1 D( b% m9 c* a% T - * TO CHANGE.
- O0 A8 d; W) k/ \* a- X/ E: L - *
+ q* x8 f8 A6 C- T - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
( w7 [# z. n7 F. h0 }. U8 N - *& _- {/ N( _5 k7 v! G
- * This program is free software; you can redistribute it and/or
$ F0 E) [, M) {/ ?- X - * modify it under the terms of the GNU General Public License as- Z1 ?/ P5 d( }& I4 ~6 h
- * published by the Free Software Foundation version 2., g0 z) I/ X- b9 ]$ V
- *
* ^4 b7 k( |! _1 k8 J) R - * This program is distributed "as is" WITHOUT ANY WARRANTY of any" A& a! L0 m* t7 h/ H4 O7 m% B2 {+ W
- * kind, whether express or implied; without even the implied warranty; l1 s+ g0 P4 E2 [4 z- g" m4 [& r
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the; W; c* i7 s# U5 J
- * GNU General Public License for more details.5 N. H& f4 W# R* s3 ~ N7 o6 z' |0 q
- */
7 a3 e2 a3 L8 l3 w3 O( D - 1 ~( w7 n# K* q+ s
- #include <linux/module.h>/ d5 e0 |0 X0 M3 Y% ~- T
- #include <linux/init.h>
" V, f) p, H& o/ B, _ - #include <linux/errno.h>, a) F) O) u: q* N3 C0 p1 S/ v
- #include <linux/types.h>" f' E) {. T8 L3 V; P5 R( ]
- #include <linux/interrupt.h>
Y; ]0 y: G0 @/ ?6 b - #include <asm/io.h>
8 G0 T; T8 N2 o* K - #include <linux/moduleparam.h>
: w4 J P8 `. \! l( n5 s0 R - #include <linux/sysctl.h>5 F3 {& }3 c2 i2 C; o# G" n- J
- #include <linux/mm.h>
+ w9 J" U# Y& e* i1 J; W - #include <linux/dma-mapping.h>
/ C1 g, n# `# P }& O+ n+ \, a - 8 F1 i* m U6 [. i
- #include <mach/memory.h>
& I v: @$ N0 @/ b! X9 E: N9 S - #include <mach/hardware.h>, ^ t9 k1 v8 S3 B, K" |
- #include <mach/irqs.h>% @2 v. I9 f( t+ c- R8 V
- #include <asm/hardware/edma.h>2 R: ~3 B# s: V# `' T
- : W% [3 ^5 \4 }5 ~
- #undef EDMA3_DEBUG- S/ ?9 g1 I& C7 Y- N
- /*#define EDMA3_DEBUG*/4 g9 g' u/ L- y$ k, c: n6 N
% Z5 B! S# P1 E- #ifdef EDMA3_DEBUG
5 [3 d' {# n3 K& ]& ]4 O2 q - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
# K0 J1 k0 h/ L) N - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
; _, C+ s$ ]; l1 g: j# A0 d - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)$ u7 e" y4 P8 w T. G* g4 |/ i; g
- #else
, S8 l ?2 |! `, r3 d - #define DMA_PRINTK( x... )6 A: |3 {. B4 c5 n4 ?& l/ l
- #define DMA_FN_IN
1 h& s( i( W0 n1 @+ e - #define DMA_FN_OUT
6 M( r, x& T ^% f0 M) ] - #endif' S9 o C0 ?$ c
. r7 s. N1 i. [/ f/ R/ J1 q' [# Y- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
% W A( B# \. t2 \' z - #define STATIC_SHIFT 3
- _6 j, W/ _" @( E) U - #define TCINTEN_SHIFT 20% {9 \. F: n+ e) B+ l) ?3 `
- #define ITCINTEN_SHIFT 21
' y8 D9 u' f! E0 a9 R) _ - #define TCCHEN_SHIFT 22% Z7 l0 F/ z* i
- #define ITCCHEN_SHIFT 23
5 v3 u; A. k7 `. T5 |5 b) i
( y N3 I$ [+ M. C4 o- static volatile int irqraised1 = 0;
" f, C2 Y" ^. Z& d( E: x0 Y, z - static volatile int irqraised2 = 0;( B, Q1 T6 S& {
: b" Y0 l9 s- Z" x5 e% ]- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);6 M, I& w, |" s: N4 u, g
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
& M+ r' J; `" c2 Y2 F+ R$ Q - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);$ s3 ?( p4 n/ S a( Z
2 i# r: [8 Z1 b4 ?" [& g& Y- dma_addr_t dmaphyssrc1 = 0;
0 R( E U7 K3 f8 I1 l9 i; U - dma_addr_t dmaphyssrc2 = 0;& q! t1 a: B# t& Z& k) r
- dma_addr_t dmaphysdest1 = 0;0 n$ K: U8 C1 X' D, {0 @
- dma_addr_t dmaphysdest2 = 0;
3 N6 J0 a" b$ b( v - # z' I% Q4 z0 s) [" I' b: |! w
- char *dmabufsrc1 = NULL;9 D( i% _6 j& M7 y
- char *dmabufsrc2 = NULL;0 X# e0 g: H! j: _. s( R* p# N) W
- char *dmabufdest1 = NULL;
I: n: C# \5 T4 T8 x - char *dmabufdest2 = NULL;0 b$ T) N; ^4 i9 }7 j0 |. w$ y7 a, S
- 6 Q4 K' U2 v2 [" [! z+ [% ~4 ]
- static int acnt = 512;/ f/ L( l1 H- l( W4 d
- static int bcnt = 8;# I, c. x! o4 K1 a0 z! N0 \+ v
- static int ccnt = 8;
% v5 i' o9 R9 r5 _+ U) n
5 B Z% q! b! d; w, J Q9 e- module_param(acnt, int, S_IRUGO);$ l: w6 p$ H. b D l7 B0 v! ^
- module_param(bcnt, int, S_IRUGO);
a3 {. Q0 Y# |9 E- H - module_param(ccnt, int, S_IRUGO);
复制代码
& J# x% W* c o9 h* p ]( ?; f- h! r7 N+ F2 z0 T3 p# p0 W# s
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
' @8 a; v# P8 U$ X. t3 D7 }5 {- @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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
1 q+ I, f; W P9 f 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
- ~4 n6 |0 o8 j4 s z/ S+ E8 {8 O: b O" R5 b8 |
9 [+ m; m( N q0 x h3 |( f+ `
|
|