|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
0 [4 B% s Y3 `+ M9 q* N: [- [code]EDMA sample test application3 w+ i/ f4 o% V
- /*) s L& U2 q2 V/ n4 o0 m6 h
- * edma_test.c
( g8 p! K" ]9 o H- u8 h - *
( o! I) {) I' g7 S2 W - * brief EDMA3 Test Application A) N9 t* K' i) x7 ~" e1 Y' v
- *
+ e* h% ^5 [8 V' T) r" U- r; W - * This file contains EDMA3 Test code.9 V3 r% C: I0 r: K q2 V/ x0 X) j
- ** p% E5 ], T, } h2 c2 ^) D
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
! ~0 O C2 q; _! r: l: T - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
$ \3 @" A( y0 E - * TO CHANGE.
. m3 g6 O) Y& a- o - *
. Q* L" D5 z. l0 ~+ n3 k/ v - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
Q5 x, ^8 x. K8 E/ D4 g - *
$ H) w8 I5 Q3 \( b - * This program is free software; you can redistribute it and/or
7 Z2 V* J; s0 l( g! G1 a - * modify it under the terms of the GNU General Public License as
9 b& m" T2 o( Y) { - * published by the Free Software Foundation version 2.
: k' F' ~6 J/ v/ H - *
8 |) h. Q- D% I, \ - * This program is distributed "as is" WITHOUT ANY WARRANTY of any
) `/ h* ], b) p8 | - * kind, whether express or implied; without even the implied warranty) ~% m) l& p( O) ]8 G: s. h2 H
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the; v9 D. \2 z, S8 |- K2 O' a
- * GNU General Public License for more details.
/ b) U8 X/ |6 H6 f - */+ Q- ]6 M( I: O, w$ S+ V
# K# Y+ u5 X/ {4 C$ J+ t- #include <linux/module.h>4 R q/ p" P5 G- Z/ v; ~
- #include <linux/init.h>2 E# k% w' I! l9 e; W( Z% M( H+ D
- #include <linux/errno.h>
' N' E* M4 b L, o' n - #include <linux/types.h>
- k" E4 s8 ]3 w6 R5 _/ o - #include <linux/interrupt.h>4 g4 ]+ V# m# X( C1 Z! e
- #include <asm/io.h>" ~" M0 m- R; p! G9 S
- #include <linux/moduleparam.h>" w" Z% n# R: R! u, c0 `
- #include <linux/sysctl.h>
& M4 \* }1 t& k; f! w - #include <linux/mm.h>
" x3 X/ G; l! p& H3 ^6 }1 f* X a5 e - #include <linux/dma-mapping.h>
/ d! k1 d+ ^/ T2 u' z0 h) f6 R4 ]
6 T( x! T5 m8 }5 o' _- #include <mach/memory.h>7 i' M* z% i8 w, ^) n% w& B
- #include <mach/hardware.h>
) e( t# r1 v/ e1 o$ z - #include <mach/irqs.h>
1 L: L# p4 X0 G% y: ?& k- u, \2 b - #include <asm/hardware/edma.h>
" l1 Q$ i2 \$ Y2 C - 5 f6 F' x9 S, H" n6 Y0 R; [
- #undef EDMA3_DEBUG
- @& K. k& E* y7 T% f! x - /*#define EDMA3_DEBUG*/* E2 k: u" ~- }; A2 l3 ~+ }
- / x) `; a6 W. [9 N* D
- #ifdef EDMA3_DEBUG8 }* T. ^; [ w" }! {
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
5 {( b+ r( z4 C- | - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
) B& x. e0 ~* y. p - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)( G# }+ O3 n( S1 J
- #else1 c! q( G! Y, J1 K( q7 X% A
- #define DMA_PRINTK( x... )
& i- _9 j8 r$ ^ - #define DMA_FN_IN
- q0 J! _5 [" W - #define DMA_FN_OUT% v2 @% m5 ?. U c# @. h) _+ D
- #endif
: W; [" k8 D" `, S - ; {5 }( }# o: K7 C. W) C: J( N; G8 f, x
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
6 d. m$ B, F# A) k - #define STATIC_SHIFT 3
+ ?' D9 i6 [* Y* U8 e9 j - #define TCINTEN_SHIFT 207 n2 F) m, ?, ?" A$ ]
- #define ITCINTEN_SHIFT 21
, ~6 n3 L+ N T5 h3 a" o - #define TCCHEN_SHIFT 22' }7 k/ c5 [$ B5 V4 c
- #define ITCCHEN_SHIFT 23
. `7 V$ D4 N1 ^8 w( e3 C% u - . _1 s- X5 L- m2 c- n+ d6 B
- static volatile int irqraised1 = 0;" `: g6 D* Z q# \, H. L% i
- static volatile int irqraised2 = 0;, g+ p: ?5 W5 \& `* e- j( J
- 9 p' [! A- ~/ k2 y8 c) a$ r% W
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);! E m' `( M0 o3 t' W8 s
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);! U# v3 k* O$ @( K+ ^6 m, t6 _' V
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
+ G& P+ k+ o% Q6 [
. j. a o4 b" i& H- dma_addr_t dmaphyssrc1 = 0;
0 T6 C% N5 v' z4 r - dma_addr_t dmaphyssrc2 = 0;) M1 a3 K: t7 R3 K
- dma_addr_t dmaphysdest1 = 0;
' g. }. R% d( Y, y - dma_addr_t dmaphysdest2 = 0;
8 q0 `; `: m0 C" \7 E* N; c - + ]% c" w1 M l8 r. d$ |
- char *dmabufsrc1 = NULL;
2 |5 r1 O4 u) ?# u+ \" i( ~1 n2 Y - char *dmabufsrc2 = NULL;
$ P: M- ]# `# ] L - char *dmabufdest1 = NULL;7 }: [0 Z7 C: X+ Z: x
- char *dmabufdest2 = NULL;
9 Q2 h5 N7 C ~$ ~ - : G8 u, A. O, S& l
- static int acnt = 512;
% K& @$ [: j7 X4 H) h1 U - static int bcnt = 8;; |+ m( A' @! ~
- static int ccnt = 8;
+ ~& A6 P2 F2 Q) f G, t' U' q
& r+ F3 ]- e/ }7 u3 B- module_param(acnt, int, S_IRUGO);) N0 w2 x! ?8 T+ ]. q: U
- module_param(bcnt, int, S_IRUGO);
! }8 z! k0 Q* ^) h( L4 \' J) a - module_param(ccnt, int, S_IRUGO);
复制代码
7 q8 H% V! o; \* c" a
; j* N A9 F% O! _) [; X3 v9 Q1 X4 u 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
2 [% y! b( g) [; c' |5 l* @- barm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
" I4 n3 I, m( p- ` 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。- }2 ^2 n; i Z6 A! j
2 [+ O- Z( m6 d9 W
4 j8 M: ^' ^0 ^4 j. Z- C) c5 n) u a
|
|