|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
6 p- d) x% J! b3 o2 m- [code]EDMA sample test application; b/ |2 C* G) C8 h0 ~" Q% A
- /*9 H8 @* X- Q9 V1 C0 Y5 h) F
- * edma_test.c8 \" [* J% j- J- ^1 N, Q
- *
* z s9 Y! g; T4 L. \$ B - * brief EDMA3 Test Application/ W" g# I& }; q: F
- *- z' F6 E0 C5 B* ~ U: o* ?
- * This file contains EDMA3 Test code.
. O# N& `- V$ B - *3 }4 K5 E g7 p& ^2 J2 v; r6 N! j
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
5 M* e3 d9 Z* f" x7 ^ - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT) X9 e2 v7 [" C6 s. z6 C
- * TO CHANGE. {; z" ^0 w! X1 g( o% P
- *! H7 K# L$ H, {2 g: R9 v3 v
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com// ^! z! W+ ^ O: r& t$ t
- *
O+ M( o d/ h2 P5 P! L' N8 W - * This program is free software; you can redistribute it and/or9 N0 }' z5 e8 t
- * modify it under the terms of the GNU General Public License as
3 S( j' D7 N7 E) s- i$ K - * published by the Free Software Foundation version 2.
& X3 J, L' a6 E4 Y2 x4 S - *- p4 e- u1 T. H$ H) O( w
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any
2 E" h. }2 e/ g - * kind, whether express or implied; without even the implied warranty
X$ R1 ~$ C8 c3 ~6 c8 F - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the L* n. C# {, V2 A2 Y+ d
- * GNU General Public License for more details.
$ P! v8 }4 x$ o# m6 x0 p1 c - */
) s7 U) v9 n& S. \+ p
6 y0 R O( D7 U) K( v* r2 j& y- #include <linux/module.h>& |, C# Z( a7 |; W1 H" n
- #include <linux/init.h>
( V+ o' x3 A7 m4 z - #include <linux/errno.h>( w C( O( O, b. h! v
- #include <linux/types.h>
4 |: t) R" C& k8 C- P% D - #include <linux/interrupt.h># l' r4 |5 I5 o& y7 c$ F0 {! `6 W7 b
- #include <asm/io.h>
+ j4 n$ r3 D q" \3 R' T" X - #include <linux/moduleparam.h>
& `9 K& k4 N8 g% A1 u - #include <linux/sysctl.h>
, c$ X, z' L* ~( l/ ? - #include <linux/mm.h>' u9 O" ]7 I x0 `* t8 y8 p; \
- #include <linux/dma-mapping.h>
# r, H2 {% A+ B, f% q3 h - + d$ A5 l+ a" Q0 I8 T
- #include <mach/memory.h>
* Q: o0 \( n" c8 F - #include <mach/hardware.h>
! ]2 C9 z! w5 `/ f" Q! o, W& R - #include <mach/irqs.h>
& ]6 {. {1 g6 L% J3 {2 c - #include <asm/hardware/edma.h>' {6 k- s+ v8 O3 a
- 2 s0 m$ R: Q7 k+ ~2 a: O
- #undef EDMA3_DEBUG
/ t6 d& n2 |9 f - /*#define EDMA3_DEBUG*/
0 A& E8 q7 f' h4 h" P - * e$ a8 u1 X/ `1 }4 H( C9 g
- #ifdef EDMA3_DEBUG, b( z$ S8 B1 @
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)1 _$ `" r* D) |! q! q. A
- #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)+ l/ ?1 K* O' d9 v( A8 U
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
& P3 z8 K, l' F5 ?; [. { - #else
; c, ?4 @- Z: n) l8 [ - #define DMA_PRINTK( x... )1 S5 w6 _ @6 Y- ?3 Z! u
- #define DMA_FN_IN1 A2 j+ }- i5 w5 T" C9 H/ ^# t$ a5 O
- #define DMA_FN_OUT6 a V3 x* }+ }# D* U2 @
- #endif
: c0 n# s6 n; ] N
" E' E/ K- U% k; C5 C) B- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
/ U) t) V: K- q. `0 O - #define STATIC_SHIFT 38 q7 }: R$ U1 A+ @$ r0 D* Z2 E
- #define TCINTEN_SHIFT 20' o; F9 G$ d; M, [8 J
- #define ITCINTEN_SHIFT 21
( S, z9 w% G: y9 a: i8 M - #define TCCHEN_SHIFT 22
* J r. ]( I% A$ I& U& ` B' f* | - #define ITCCHEN_SHIFT 23, R2 W/ }- C, K5 s3 v) z
1 J5 S' s$ Q5 T% C9 [- static volatile int irqraised1 = 0;
5 G6 m# T1 s0 T9 B: L! E3 N - static volatile int irqraised2 = 0;* f S- b5 I' t0 o9 h
* Z1 x, B; E7 B0 F% o0 R; i- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
j" j& y$ G8 v# h) ^) H - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);4 v) i( J9 }& X: K
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);( P7 s9 c: D7 x5 H5 v" }4 u
" s! Q3 u; a2 }: R3 l- dma_addr_t dmaphyssrc1 = 0;; y9 K( |/ q/ H
- dma_addr_t dmaphyssrc2 = 0;% p# S% C4 H0 G* D8 |7 j
- dma_addr_t dmaphysdest1 = 0;
+ d2 H/ ?3 l+ f, [1 g( I7 r* \ - dma_addr_t dmaphysdest2 = 0;
7 M3 n5 f$ m* U; A# d
2 V" `5 W* {) o8 s- char *dmabufsrc1 = NULL;7 K7 x# I5 x3 j7 \
- char *dmabufsrc2 = NULL;
5 R2 u7 ^1 m& I" B0 S - char *dmabufdest1 = NULL;0 n; @3 I( H7 Y4 q# W/ h" A
- char *dmabufdest2 = NULL;
( l S0 T1 s' V* f - + }! B+ g n" o0 {+ W: ^
- static int acnt = 512;
% L2 N% U4 I- X7 s' {4 o1 ? - static int bcnt = 8;$ z/ B2 l7 `' H. N& } h: F
- static int ccnt = 8;
7 }- {4 T$ m9 o0 i: D9 A
5 j2 X# u9 o3 q( C- module_param(acnt, int, S_IRUGO);5 p: Z$ R, C0 c- J
- module_param(bcnt, int, S_IRUGO);4 ^5 m* Z/ R l+ N% t
- module_param(ccnt, int, S_IRUGO);
复制代码
; Q% v0 y; P$ r6 ~" Z( k' J' s$ A9 O7 p
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用5 }. @1 m( D! e/ R. J
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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
) T9 Q6 t1 [2 P0 V! ] 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。! T& d2 |3 ~" I: k" @3 T5 f+ u
5 ^7 x F+ u e7 i+ J; X, R4 [, R
( ~# ?) J8 x! ]5 |( I! ` |
|