|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
* U8 g5 M, m- y5 J u6 S- [code]EDMA sample test application
2 ?( e; v. e8 d2 q# j - /*
: h" i- e5 b8 } - * edma_test.c" K$ l* x! I- k6 M% g) x
- *
5 \! a# `/ T" e* b0 S4 }; c- v - * brief EDMA3 Test Application( U1 S' d C8 k. Q/ |0 [ C+ ^
- *1 ^; l, X" k5 ^0 ]! u4 }
- * This file contains EDMA3 Test code.
& i/ V/ f+ l; u+ r5 H( r, ] - *
- E! h p$ o! {! w" R. | - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
1 E+ U. X# k9 o& f' r0 ~ - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
. ?9 U1 d9 d2 j - * TO CHANGE.6 g: U" L0 I/ k5 G( {
- *# i/ v9 f$ l# t# d/ B
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
1 H0 W9 M9 R, O( T5 c3 [" i - *' b o2 [& h3 o; x+ @
- * This program is free software; you can redistribute it and/or
" Y0 D! v* \; U8 ?- @( Y - * modify it under the terms of the GNU General Public License as# S4 K0 h( k! i& @
- * published by the Free Software Foundation version 2.
. ]% y8 {4 }/ U4 v - *
{2 w1 ^" q& y6 Z4 v. m {' x - * This program is distributed "as is" WITHOUT ANY WARRANTY of any. `7 y" H0 v- c% _% U" c
- * kind, whether express or implied; without even the implied warranty8 }9 }/ {' l: D4 r' r& f/ G8 o& t1 y
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the3 p. B6 T5 B% C) W' U
- * GNU General Public License for more details.3 Q8 \1 E! k! {* ~% W
- */& }4 V$ X( }* j1 ]) q
+ F0 N1 f0 P# g, L; I0 U8 G- #include <linux/module.h>
5 b% `. I3 O% O4 H3 c - #include <linux/init.h>
# E; _( o# Z- h7 y0 t, g9 K - #include <linux/errno.h>6 J8 c: d0 Z9 f5 L$ q
- #include <linux/types.h>
3 N9 m# }) _: h9 N& b - #include <linux/interrupt.h>
4 M& W9 |+ h, y - #include <asm/io.h>
# y; K. a, ^; D9 R) o3 Y - #include <linux/moduleparam.h>
) m9 ~- C3 k T* ?( E- Y5 T - #include <linux/sysctl.h>- U N- Z# Q% l9 R. p9 d* b8 [2 E1 j
- #include <linux/mm.h>9 y" M& P' e; D9 y3 b$ W/ J! O U7 o
- #include <linux/dma-mapping.h>' k8 i6 p4 b, H
# O! g% e( k0 C# [* S, f `- #include <mach/memory.h>
+ [: q g( l: P* u% d( s& T: Y: H - #include <mach/hardware.h>
# t; Y9 t9 ]0 [* G- G - #include <mach/irqs.h>
+ s* U4 N7 v4 I* j - #include <asm/hardware/edma.h>
- w) P0 h* h p+ ?# Y - 3 a1 Y/ ~* x' ^& z
- #undef EDMA3_DEBUG2 D: N3 [% J& k( Y# b
- /*#define EDMA3_DEBUG*/+ Q, `1 a N" E5 G/ [! b
- # z$ J- c* y. A1 G" j9 N* ^
- #ifdef EDMA3_DEBUG
; E: W. C c0 ?% n- d% a- I) A - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
, A* x) g0 ]- |8 {( s2 M" ^ - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)( E5 e! k8 y8 a4 J0 V' C
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)" P: V+ Y7 M* B$ T% h- C8 s. J
- #else
% R! {4 r; x9 f- s/ \5 j* c) g% ^ - #define DMA_PRINTK( x... )* L/ V: P, \9 x- ?( i
- #define DMA_FN_IN
% f o& r B$ R9 ^( V - #define DMA_FN_OUT
5 {. G5 M9 K) S! k, N - #endif
. Y$ j8 u8 ]! @) N
) Z& H$ N# Q6 _ y2 ]) `( }- #define MAX_DMA_TRANSFER_IN_BYTES (32768)* u: G n- `, ^! }3 P$ F4 I2 V
- #define STATIC_SHIFT 3& ^! b: P1 ]; V3 ]- H; Y
- #define TCINTEN_SHIFT 20' I# ^9 b/ {4 K B' e! k9 b
- #define ITCINTEN_SHIFT 212 V3 S& Y, m1 j1 ]! W# v# W
- #define TCCHEN_SHIFT 22/ v0 }+ ~ n H4 R- V5 S+ h$ p
- #define ITCCHEN_SHIFT 23
: q5 @% J0 b% j5 S& K
, U/ K5 j9 `% ?2 {, m4 K- static volatile int irqraised1 = 0;# g: j" Q! g+ q9 V
- static volatile int irqraised2 = 0;1 a5 R7 u: o/ {2 l* P
/ m) j8 \5 \+ z" v) f* ?. T! f- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
+ c$ j* |" X* Y: s, \6 p& J - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
& t# ?, n S! W) A; x, j: q% f( R0 y - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
. n. S1 {0 o4 e/ `# e: j5 t - 8 a: ]4 s( c. X
- dma_addr_t dmaphyssrc1 = 0;
, }# a. Z7 l. j0 ~5 r - dma_addr_t dmaphyssrc2 = 0; {# u! l. H# o2 N
- dma_addr_t dmaphysdest1 = 0;
( q: b1 W( [: ~8 V: S - dma_addr_t dmaphysdest2 = 0;) p$ I1 l. `! L! y9 Q& K3 ^
- 3 v7 d! L9 q8 o+ m8 _
- char *dmabufsrc1 = NULL;9 l% G! k6 g+ x$ [1 [
- char *dmabufsrc2 = NULL;
4 @5 c9 S. _" v% m - char *dmabufdest1 = NULL;! w1 p7 ]; I5 V9 j1 }
- char *dmabufdest2 = NULL;( f, J8 _$ d; r$ P
- / ?3 Z0 n1 H; D) L% N/ E
- static int acnt = 512;$ s" v# M; `) E/ O
- static int bcnt = 8;
" V% d% e' o+ }: J4 Y- H" e) Q - static int ccnt = 8;# ~5 T5 e5 ^* i3 k
% }+ K3 b* E7 j- u) t. m- module_param(acnt, int, S_IRUGO);
, G A D4 ~: ? - module_param(bcnt, int, S_IRUGO);
+ W0 [& x, C0 j% U4 n - module_param(ccnt, int, S_IRUGO);
复制代码 8 e9 ]/ E6 v7 }4 y6 _- |
( f/ }+ V# G/ j; I: \% S 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用. o: k- q' Q. x2 }, @; 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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。6 }( Z7 S/ e8 ` [4 S' i& z5 ]' M
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
$ w+ b2 H1 @* a: Q: B# l8 ]$ A8 K2 E. q3 @
; `: u4 {+ U/ }3 @+ m
|
|