|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
5 Y/ S6 H3 J$ k4 h! D; o! E& J+ B- [code]EDMA sample test application
8 ?$ _0 j b/ |3 R# S3 J% [ - /*; g( Y% @. `2 c5 Z/ Z! ^) i
- * edma_test.c
6 j; L4 q$ n1 W- W9 d - */ M% T" e8 a1 K+ \. J
- * brief EDMA3 Test Application
* H( e8 `! _% t/ j# E! \) W& [ - *
. o _/ ?) }* w2 o: E$ e$ t - * This file contains EDMA3 Test code.1 Z3 J. x% W; D- Z$ y' [/ x
- *0 p8 _2 h& M1 s8 `
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
8 t# l* l2 W: L1 j' a/ m! { - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT# F) y1 z$ B/ u
- * TO CHANGE.
, C* g: Q0 ^9 J7 L( D- ^ - *
/ X8 G/ A8 t: f2 C0 w - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
' C$ G7 o# r m9 Z: T" D& U - *5 d* X! H9 {5 c0 ~4 E9 n
- * This program is free software; you can redistribute it and/or1 R1 t5 n# \9 ]
- * modify it under the terms of the GNU General Public License as
: J9 q0 _; s8 ]5 Y- T! u1 |) O - * published by the Free Software Foundation version 2.
) i" m6 E5 ^. G6 k - *3 g r1 l# K$ n/ b
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any6 q3 x: G* n. u0 Z
- * kind, whether express or implied; without even the implied warranty
/ Y# P1 \/ g& d - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
/ R7 [- a( j# t; y5 @* L$ Q - * GNU General Public License for more details./ D! R5 R6 U$ p8 _1 O; u5 z6 h. W$ q
- */
% V* C$ b) a- B7 f - - }- r" S# ], Q* p' c% `+ a
- #include <linux/module.h>$ Z5 b& S1 R4 {$ B$ M3 ~
- #include <linux/init.h>
0 l- F4 x! a& D( b( b - #include <linux/errno.h>
) M* ^3 }# P' A, o - #include <linux/types.h>; v9 u; C1 S8 c3 o. y; a% ?
- #include <linux/interrupt.h>
' T; q; W+ E) r9 x4 |: K - #include <asm/io.h>6 ?/ x {' b T8 s( X: }# n
- #include <linux/moduleparam.h>
: N' N% q. n' r* \" H - #include <linux/sysctl.h>! \4 t+ N+ m& O) s
- #include <linux/mm.h>
2 s2 c/ p1 X2 g4 i1 M! v - #include <linux/dma-mapping.h>6 |% L! ]% B0 N: L6 q5 D7 u
4 {0 s7 B8 ~+ `& f' u) A- #include <mach/memory.h>* o; Y2 T7 }& s! n f
- #include <mach/hardware.h>
6 Z. v5 h4 d, `: }; ` - #include <mach/irqs.h>8 a. o' C+ j2 ^! W2 i% r- s6 l
- #include <asm/hardware/edma.h>
" d9 S( t: Z% U8 e+ W o - ! h1 p2 R8 A! r
- #undef EDMA3_DEBUG
6 s# I- g$ O; ^, q- T& x* v - /*#define EDMA3_DEBUG*/' L! }/ Z( g5 C# ?
4 J9 z4 J5 M6 N E- #ifdef EDMA3_DEBUG0 K w0 `4 n$ D# b6 H+ p
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)/ F+ T/ J; |9 P6 p+ e
- #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)3 D6 i4 t: A6 v5 f/ p
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)3 g: @) A( i9 n/ P2 I9 o1 W5 z
- #else' A! j; E: c) Z: W
- #define DMA_PRINTK( x... )
+ \. B$ k' U, L/ {5 j- }& ` - #define DMA_FN_IN
# X( N9 S1 v- Q! r2 n - #define DMA_FN_OUT
- W8 w) c; P9 }1 @ - #endif* ^' B; O' k1 g: m( O
3 K+ H3 i6 C Q# t/ _& v# B- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
8 }$ T) K- W3 @/ P' I - #define STATIC_SHIFT 3% \. K* T5 T: l
- #define TCINTEN_SHIFT 201 K; I9 O9 O0 {( a" J" P- y0 q
- #define ITCINTEN_SHIFT 21
( v" d, E6 Q/ @5 x4 e# L* }, U, J - #define TCCHEN_SHIFT 22) N- u6 u6 N4 f, L' N: _# ?. D* S
- #define ITCCHEN_SHIFT 23
- P: h' d! Z* Y& e5 q - 0 b9 z# l+ a# ?
- static volatile int irqraised1 = 0;
% r6 j8 i Y2 g9 T5 c- K - static volatile int irqraised2 = 0;: @) e. G. t& c- Z' o9 Q7 K
- ) F4 u6 b5 b9 ~
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);3 z G5 g5 H- H' C5 v. K( q2 P
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
7 L/ q1 w0 t, z; p1 N - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
8 [; A8 z* N0 Q5 r( x3 l5 u - 6 G# L& w. H$ M, S, t, R2 B* k
- dma_addr_t dmaphyssrc1 = 0;. e( U0 Q1 b7 C! u6 j; Y7 o
- dma_addr_t dmaphyssrc2 = 0;, i- j, M5 R" z; ~. c/ s/ e
- dma_addr_t dmaphysdest1 = 0;1 H' ?3 ^+ O/ ?
- dma_addr_t dmaphysdest2 = 0;
) U- I Y5 f+ ^/ k3 g - 3 I3 ^' X5 N: g, U8 W
- char *dmabufsrc1 = NULL;
) r c1 o3 j: z; y$ X - char *dmabufsrc2 = NULL;
+ k! E3 o4 `/ y' P8 C - char *dmabufdest1 = NULL;: W$ d+ Q9 Q, C: ]
- char *dmabufdest2 = NULL;
; s2 t. e3 ~3 g* Z
+ f2 U% `* p) p" v) g5 W! \% R$ t- static int acnt = 512;7 u9 K8 z& ]" y
- static int bcnt = 8;) e7 P( b' w t) G1 e
- static int ccnt = 8;1 h3 a7 {: |9 U4 S% w/ F6 R
- $ ]" b" D$ x1 ?- n
- module_param(acnt, int, S_IRUGO);
+ J! P7 O5 f, p4 q/ C( X' j" { - module_param(bcnt, int, S_IRUGO);& }2 H, K( p0 U) }# U3 [( j5 \, j+ A* ^
- module_param(ccnt, int, S_IRUGO);
复制代码
% {! ~$ I& |- K7 y# Z, p! x, @$ K& d6 X N- Y7 w$ p: z( r
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
8 P2 n8 s6 `/ {& ~ sarm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。+ q4 b2 Z: ^% _0 I) m F
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
2 m9 C3 S1 X. b5 V
- E* r# B5 f8 m0 n( u! o
2 y: p% K! E: i( q4 Q |
|