|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 & g" g! H; q" u$ k5 z4 y
- [code]EDMA sample test application
6 @, E4 o/ a) _- D - /*
8 h7 t0 _) w+ `3 M - * edma_test.c. K) n# Z. w! E
- *
2 j# t) G9 U& n+ Y! X - * brief EDMA3 Test Application7 |. m; G$ \0 {, c/ z7 U/ J
- *
8 n; \ M) i7 x: w0 G* P - * This file contains EDMA3 Test code.
, f& O' Z* W1 G { - *
% H5 q1 w/ _2 T" A7 L! w: i - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE8 T# A% Q% |$ f+ g# ^, r
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
. b2 |" l; v! J3 D# a, @ - * TO CHANGE.
* H/ S6 D, I. e, K8 Q% d - * G: r- I" v: Q; y9 }: N8 m
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
- z# o3 i. F% @' W/ ]- { - *
" k8 F! d1 [$ x% J6 `, P4 ^0 l - * This program is free software; you can redistribute it and/or4 J! H2 m: y+ U# v/ ^8 @8 B6 S
- * modify it under the terms of the GNU General Public License as: D" w8 F: u" u# n( S V
- * published by the Free Software Foundation version 2.6 G/ k V ?0 l w! @& V8 y
- *
8 B5 z& h) `! \5 @ - * This program is distributed "as is" WITHOUT ANY WARRANTY of any
, b$ M; J/ R7 \3 z2 n; p - * kind, whether express or implied; without even the implied warranty/ \. L0 J% p' d) L+ C! a8 {
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
& l' O# W8 B5 l G6 K - * GNU General Public License for more details.+ T4 Z8 F. s! r2 u4 |2 V8 {
- */
% X& t: [. Z/ W! Z* B0 u - ; O/ Z0 _, V; }
- #include <linux/module.h>
6 o% ~% p6 _4 k/ h - #include <linux/init.h>: A6 m v7 l$ C& N7 N: [
- #include <linux/errno.h>
1 I+ c9 y, C. R0 M - #include <linux/types.h>
$ m3 b- B: `: t$ r: o - #include <linux/interrupt.h>
" A1 t V* J* O' B) s/ L$ x - #include <asm/io.h>. S+ N h |2 t1 [% M u
- #include <linux/moduleparam.h>8 r( @5 I6 u$ @! }1 g7 U
- #include <linux/sysctl.h>- g# C" R+ b+ {* J0 p; I
- #include <linux/mm.h>) k9 j; A' C0 k4 a, F7 G
- #include <linux/dma-mapping.h>
5 l) ^: b' n- S! t - 5 n8 b4 Q% N* _
- #include <mach/memory.h>: ?0 [- J4 A4 m$ w* N! g7 F
- #include <mach/hardware.h>
/ \- g4 e5 _% O: ]7 z5 m# | - #include <mach/irqs.h>) [, ~1 k4 T3 G- m0 P1 F
- #include <asm/hardware/edma.h># z0 ]$ z2 T6 U' T8 s$ X: `: I- O
1 ]2 j) q) e) M/ M. ~- #undef EDMA3_DEBUG) v( ?- s* o' W* K1 c
- /*#define EDMA3_DEBUG*/$ R0 H3 I- k* V0 H* G4 o
- : L+ B9 t- \# J( Y
- #ifdef EDMA3_DEBUG
b* }+ F$ B$ ~5 I8 d* ^5 i - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
% D$ H1 ?( W, I* \0 D - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
U% ~: ~3 ^1 K+ H5 n1 Y6 _$ o7 C - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)$ V- s- |% j+ x' d O
- #else m% p4 f* a. k" d# [9 x8 h6 E) p
- #define DMA_PRINTK( x... )* {) N5 ^% W7 z% s1 Z+ B9 l
- #define DMA_FN_IN
* V" H4 _. j0 a1 Z8 @' y - #define DMA_FN_OUT8 c* F C# T5 R
- #endif
7 R! d5 K+ E8 t5 T; w5 s
4 n) z( R3 }/ [1 }/ B; U. K- #define MAX_DMA_TRANSFER_IN_BYTES (32768)$ z- ]& ^9 [4 N, ~7 u( n& |
- #define STATIC_SHIFT 32 l, E: v1 ]* F, m0 @/ y X
- #define TCINTEN_SHIFT 20
4 d& b6 Z: F( }' N* ^1 {. Z% q - #define ITCINTEN_SHIFT 214 E( x4 l3 q& g
- #define TCCHEN_SHIFT 22
: t+ H( E+ a0 d) [: G - #define ITCCHEN_SHIFT 23
2 g: n: N& H8 b/ z5 h% R
& T+ k2 l' t9 `& O. F- static volatile int irqraised1 = 0;
% P- l! E& F2 z- q9 s6 W - static volatile int irqraised2 = 0;9 W- o$ r/ m% n- [& s
5 B3 S+ z1 S' q" T. M6 i- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
6 s2 t8 w. E* H, i+ D, J6 _8 i3 f - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);: E" q r5 W* c; ?( A
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue); W& \+ f+ f3 D
- " V; V% i" ]0 j& v
- dma_addr_t dmaphyssrc1 = 0;, H2 [# r3 `! e% e( N& i y
- dma_addr_t dmaphyssrc2 = 0;/ M7 k6 _0 d5 A- _& g6 N6 ?4 }
- dma_addr_t dmaphysdest1 = 0;& s# {, v. k4 d7 E" u' [: M1 w6 s
- dma_addr_t dmaphysdest2 = 0;
: g# K+ ?! `7 _& y! ~" A- }% q - 7 V, B! v' j2 O: K$ v) B4 H' S
- char *dmabufsrc1 = NULL;
3 a) s+ h" ]: m; H& w - char *dmabufsrc2 = NULL;
( q+ ` g+ R3 x# W - char *dmabufdest1 = NULL;4 C N) d7 O1 G
- char *dmabufdest2 = NULL;
6 ^, Y/ k1 D, y6 R5 u8 y" w7 I
3 N$ a+ s$ Q S# \7 c- static int acnt = 512;
4 }( B+ ~# T; d1 U8 E' Q) ] - static int bcnt = 8;
0 @% u+ r& ~4 m+ R0 k8 W" l - static int ccnt = 8;; [( O1 Y5 y3 q) O, ~& Q; T
- ; M% F$ R9 k" R% Q9 ?: r
- module_param(acnt, int, S_IRUGO);
. K4 R' o& C5 @; m! U, q& Q - module_param(bcnt, int, S_IRUGO);
) Y" F. B0 ]; O9 \% w% Y - module_param(ccnt, int, S_IRUGO);
复制代码 ) l% @5 P6 J/ U8 y: r
/ r+ L" [& H4 }3 u x( I: c 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用: A7 S! n- z: B6 h+ {; n
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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。+ T+ C+ y6 J5 M, _/ b8 f9 O
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
# f1 G h3 [! E( y7 H
& V) e0 L" u7 k6 E3 W+ h% Y6 c5 r3 ~4 F$ K# j% ~- w
|
|