|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 % K* j1 x3 l1 }1 _: T3 x" {; q* D! Z
- [code]EDMA sample test application/ j) F* g+ r, b8 k
- /*, {& _: t0 r$ j. q9 {7 _
- * edma_test.c
) b, H- ^3 d; U, l, F - *3 @) ~5 f% {9 e* L
- * brief EDMA3 Test Application
3 E s1 I5 q9 g8 R - *! f5 S; T$ |; r) |) G, ?
- * This file contains EDMA3 Test code.8 p3 z7 P1 G3 `8 N% E! z
- *8 H4 K: n% }9 W6 g
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE/ b! k3 I5 P+ t; H. z8 E
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
4 b8 E1 D( m0 w& `* A - * TO CHANGE.( o$ h& `7 I2 A! _4 [
- *8 n/ D2 A' f( b& c5 U
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/+ _' D7 M9 X; S! `
- *
' G. g/ Y! F4 ?8 m - * This program is free software; you can redistribute it and/or
+ r. ^ |6 G/ F - * modify it under the terms of the GNU General Public License as
3 W- C7 K3 |- I. W - * published by the Free Software Foundation version 2.# G; \. @9 b. Z5 n" n
- *
% Q" o2 J0 V) ^8 v; u - * This program is distributed "as is" WITHOUT ANY WARRANTY of any Q8 O* R2 i; X/ Z* x0 a
- * kind, whether express or implied; without even the implied warranty7 W7 p- `& A, c# m* K* f
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the1 @8 P5 w9 J: B. ?% x6 V/ I6 w
- * GNU General Public License for more details.
5 y, j" N$ R/ Z, r; j& ? - */- b# W1 E+ p0 d; d# Q- p5 j# P$ x" y
- 7 y" d* l1 p6 U+ o& b5 g% \6 U
- #include <linux/module.h>1 z/ S2 M/ p8 ~. S: y- C
- #include <linux/init.h>
3 T; U, q, Q! ^, G2 m - #include <linux/errno.h>
* g9 [2 I% a: c8 ? - #include <linux/types.h>
# M ?0 \6 M X: j0 Z - #include <linux/interrupt.h>" J. S* ^" E' o3 m
- #include <asm/io.h>
# ^% I1 Y( z/ j' K& P5 e - #include <linux/moduleparam.h>
& d5 }7 _) }* a$ w: R5 V9 [: z( \ - #include <linux/sysctl.h>1 _' I5 D. n- v2 m- D5 G( o
- #include <linux/mm.h>
+ |" G! U$ o; z9 F5 p H - #include <linux/dma-mapping.h>9 s6 J. Q# o; T. _
2 ]& N3 ^0 M2 _% A- #include <mach/memory.h>
" o6 x3 K; F W, ? - #include <mach/hardware.h>
' M- D5 D- i0 A2 x - #include <mach/irqs.h>& z4 \9 U. _$ Q" O0 T1 ^" H
- #include <asm/hardware/edma.h>
) ?! C1 Z" i$ {. q, \; Q
; L8 m. ~8 O9 z9 d! h& d- w8 O" O- #undef EDMA3_DEBUG
- o$ M! [, e; U - /*#define EDMA3_DEBUG*/# ?4 ]# j0 ] _" U0 T
: R; ]; J2 a0 f* W9 l% K9 |- #ifdef EDMA3_DEBUG& F/ f/ | h- i/ q6 H- E. \+ y
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
: M/ G1 B" K- O8 W6 \5 u - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)9 G# f" {7 Y3 k+ u+ T
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)+ t& |! @6 k" h. G$ y0 ]
- #else9 m1 |4 z$ c$ R5 @0 U T) M
- #define DMA_PRINTK( x... )9 }8 F: }! B, C2 m+ A: I
- #define DMA_FN_IN
/ J" s" X$ Q4 i, N5 a7 _$ D - #define DMA_FN_OUT" c/ I9 ^ T2 W3 W+ o
- #endif
! V( q: K: b- J, M" D7 s3 v: m
) y; _0 h/ }# o6 X; @- #define MAX_DMA_TRANSFER_IN_BYTES (32768)$ X4 g6 F* t' V2 }* n. E) d
- #define STATIC_SHIFT 38 y; `" r4 c l: z
- #define TCINTEN_SHIFT 20+ ~4 c* d2 L5 }- h1 C
- #define ITCINTEN_SHIFT 21. q( p' z& ?' Z7 K3 D( A
- #define TCCHEN_SHIFT 221 h8 ?+ z) ~+ R5 t- L- `; _
- #define ITCCHEN_SHIFT 23
; W( N! U" y7 n1 b Q/ q$ I0 k
' j$ m' }$ I: s2 I- R% e, g+ ?. I8 h- static volatile int irqraised1 = 0;. t4 @3 b1 ~7 [6 @. R
- static volatile int irqraised2 = 0;' \( a2 i' U' [) {3 p
/ \8 X+ G- F" S- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
4 ^/ r' q5 @, h0 t! B5 ]$ j - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);4 k0 n8 v: h+ [
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);3 i7 r$ Q- C- n# K2 U Z
$ h& |) j; @, K D1 q- g( A# C- dma_addr_t dmaphyssrc1 = 0;2 \" a i. J, m# I' N# d
- dma_addr_t dmaphyssrc2 = 0;8 P2 T' [" @4 \+ w' F7 z
- dma_addr_t dmaphysdest1 = 0;
B" r G0 D. Q* D, q1 C/ k - dma_addr_t dmaphysdest2 = 0;* @% m4 Z5 `, d- U$ k O
4 P% P( {2 {- l0 a8 ?( c& U- char *dmabufsrc1 = NULL;4 d$ b X% d7 X4 E P. n
- char *dmabufsrc2 = NULL;
+ \; F3 e/ K( E/ \1 z - char *dmabufdest1 = NULL;
5 |- N* b; v0 Y5 I1 ^( s7 R, d - char *dmabufdest2 = NULL;/ O' Z% b! H4 e, K9 ?! i {
; G( _6 X+ X$ ?" Q \0 A& L- static int acnt = 512;( e' E2 _) A" K6 D/ ~5 G
- static int bcnt = 8;) p3 O2 {' ?/ Q+ D( Y
- static int ccnt = 8;
9 `+ k+ M0 E) R$ h
& X. u2 |: H7 }% B# a# i- module_param(acnt, int, S_IRUGO);
6 \& c8 q, A4 @1 I q1 ^ - module_param(bcnt, int, S_IRUGO);" h& I) N0 F+ Q3 E3 E: \4 e
- module_param(ccnt, int, S_IRUGO);
复制代码 . O4 o- b* T2 S; t8 g; ?% z+ d* ?8 q
- H: J! B% O5 U; U5 L8 D
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用6 k! M% C+ e. d2 o! z$ T
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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。# O( H5 o5 }8 w2 r J' @$ o
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。 Z- z, u2 |. K5 Z$ E6 w
6 n. p) t# K h4 w% u, S8 J' M
) a7 z) @8 n) e5 x) X |
|