|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 $ W. r, H: b( s0 `+ p
- [code]EDMA sample test application& S, Y" b6 w& A! J+ H
- /*
7 D- {8 _% _" [5 J; m - * edma_test.c
; C- t& N8 A. |! |" B - *# l" L, A$ \4 f
- * brief EDMA3 Test Application9 t: y( T6 J; n- @- O+ [: {
- *( B" {2 k& Q( {) [7 C) T" G
- * This file contains EDMA3 Test code.1 P/ k# Q* ~+ e. Q4 Z! R9 _
- *
+ _( j2 X1 X X( s9 p1 ^& N1 v% G - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
- w5 O2 N2 z3 h9 P& K8 { - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
; e; o& z' N% d1 m2 M, }; t - * TO CHANGE.
$ p9 P8 O/ c2 S. E1 m - *
" X/ n" I$ z9 h! E, P1 J - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
+ o, r! T/ d! \1 g- N - ** s- K6 y3 d8 v( I& ^
- * This program is free software; you can redistribute it and/or
4 c* w( G1 M& ?2 | o - * modify it under the terms of the GNU General Public License as
: b) H) M/ X/ k1 z+ R, w0 |# `9 R - * published by the Free Software Foundation version 2.
c0 c6 e: \' a, s7 C5 d2 v - *- p8 x/ h5 G( _7 l) E( O* c
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any9 m4 B* L1 x/ m
- * kind, whether express or implied; without even the implied warranty; ^9 o3 J9 p; I4 ?3 b
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ Z4 o. S6 Z+ W: x& d - * GNU General Public License for more details.# p% w& h0 ]) a# a% m, G1 y
- */
! ]/ }3 U$ U8 z; X! [5 Q3 S/ |
9 v0 V9 X! A* h4 F1 g1 M3 D$ }- #include <linux/module.h>! f. \9 g1 b& i' g+ `' Z
- #include <linux/init.h>9 h( Y* V( Y3 Z; ^1 j9 d
- #include <linux/errno.h>
( o' x# ^! u; \% k7 [9 h- x - #include <linux/types.h>
+ l5 R$ l% b' _3 p - #include <linux/interrupt.h>
/ p% ?( D5 r9 W. G& d2 b4 j" A- R - #include <asm/io.h>0 ?: v8 E+ l9 @: ?2 S
- #include <linux/moduleparam.h>, k0 x4 i+ l& H7 p4 O% Z1 X
- #include <linux/sysctl.h>" q6 W2 z# n! Y2 e' F6 S
- #include <linux/mm.h>( t a) p. A1 d; t+ c0 }
- #include <linux/dma-mapping.h>
W6 p }4 G: e) e, d8 Y$ Y - ' K8 f% v' f: t2 T
- #include <mach/memory.h>& ^! n7 G6 [& e) k) u
- #include <mach/hardware.h>
# f( j$ E8 P3 f3 d" I - #include <mach/irqs.h>
9 E( W& [- \' u* f) Q* b" W" V - #include <asm/hardware/edma.h>
: Q7 @8 _+ h8 {: J
]; w3 E/ F2 x/ X6 W6 ?7 b- #undef EDMA3_DEBUG, d2 \/ I$ k8 F
- /*#define EDMA3_DEBUG*/
- w$ K2 T7 J- w - ) `7 M- h, ]. s8 p2 j9 i
- #ifdef EDMA3_DEBUG
* J0 b- i& J/ j7 K' ~ I/ k - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
+ x5 }! i$ D; e0 [- _ - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)1 p; [* u1 S2 J& o; i6 Z' E
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
4 z' X- |; v! z, k. m5 |/ i' f - #else
: j+ f( i% h+ v - #define DMA_PRINTK( x... )- k6 Q# l$ {8 W( I: M
- #define DMA_FN_IN5 r% m1 K7 s) x; ]- r, k
- #define DMA_FN_OUT x$ S& Y J# g8 s9 ^
- #endif
2 t: T- G6 {9 W& F2 R: u& Q) ^ - e5 d' ?; \: ^% F& r
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
6 ^$ B8 P8 p! B - #define STATIC_SHIFT 3) N" R+ C$ Q1 }% ~$ A5 w. c
- #define TCINTEN_SHIFT 20
- ~; `) ]9 }: [ - #define ITCINTEN_SHIFT 21* v& r R" T8 \% s+ z8 p
- #define TCCHEN_SHIFT 224 H6 u0 e" G$ @! e8 E
- #define ITCCHEN_SHIFT 23. X R$ p4 F8 t+ J# s
5 L/ B8 s [" a$ o- static volatile int irqraised1 = 0;8 \$ H' a3 u- K5 B; D
- static volatile int irqraised2 = 0;
$ } C) [+ Q& M r - ; f8 B$ C7 p1 P5 ^9 `
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
9 E* K" k" u$ b5 C6 M6 s - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);$ T' ~# r/ p6 `- V% O5 V- B
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
* m: w8 R/ n3 G8 Y1 I
+ Y, a& h( e6 M1 S) `/ U- dma_addr_t dmaphyssrc1 = 0;
: j) l! V! e) N; V - dma_addr_t dmaphyssrc2 = 0;7 _1 l4 s6 D8 P9 D% w* b& S
- dma_addr_t dmaphysdest1 = 0;
0 N7 \# S5 I0 i - dma_addr_t dmaphysdest2 = 0;
0 S t$ i2 r) R* I9 \- g: s* n; z0 y( Q
& u* ` y6 f; G5 d# E& [8 s6 A- char *dmabufsrc1 = NULL;
2 _3 k* m3 R5 r6 h }# | - char *dmabufsrc2 = NULL;! b9 j4 [: P x6 X, h3 z( q6 Z
- char *dmabufdest1 = NULL;
: @; B6 _0 I" `% t8 e; M' n - char *dmabufdest2 = NULL;* x. G, D: e- U8 ^' _0 P
- . `; s8 ]* m5 D. g5 O) m
- static int acnt = 512;6 b5 u# u! e! P6 g0 D) q9 x0 e/ m
- static int bcnt = 8;6 O. H' v/ {3 c5 @: o( |9 R, X3 R
- static int ccnt = 8;; X5 K( }- m) v( g
- ! F' F6 P: a; y' x1 H
- module_param(acnt, int, S_IRUGO);: c5 f/ `# w J" c
- module_param(bcnt, int, S_IRUGO);
2 |$ z u, F+ S - module_param(ccnt, int, S_IRUGO);
复制代码 ( G9 }* @/ w% K( s# F- i; ~4 J7 Z( K
7 R8 [; x" }5 c9 l* ?
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
1 T3 Q$ l( e) L O% l* harm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。# q6 k; u3 x, H' [
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。# \2 d( o6 s8 y) T$ v$ u, ]
) ?. Z9 Q8 o1 F, U n
, A( c) C- U' ]& ]7 m- J; \9 W |
|