|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
2 s, \$ n9 P9 I% I/ Y- [code]EDMA sample test application
" a, |) [, c4 x. O - /*
" t- }5 n1 W; E4 f( r& U+ d3 F) z - * edma_test.c4 U! I5 g" h0 J1 ?0 ~/ S. a7 j8 w
- *
h- ?' C, T5 m/ U - * brief EDMA3 Test Application$ J) ?8 T9 ?& s, r1 {: U' k& _
- *
' {6 C/ X: q5 [' N7 s5 H" o. ` - * This file contains EDMA3 Test code.( \* I8 G% ^. B% x: T! l
- *
A9 ]: F/ s- r' F& Q. ^3 H! R - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
/ p/ u: L; t i) y$ S - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
( e8 b$ I3 s; r6 i/ I0 ] - * TO CHANGE.
6 C/ U; C& j/ X. m0 j - *
7 U# E/ D& [( C - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/8 s# f y5 K9 R* f
- *
( P7 G. A i: G$ C( W! B3 o7 B# e+ | - * This program is free software; you can redistribute it and/or
5 t: l' q2 p, i5 A: G h - * modify it under the terms of the GNU General Public License as. D. R1 b8 P" m: @+ u& s" J1 D0 H$ n
- * published by the Free Software Foundation version 2.
2 Y% ~) l; O6 }+ l& K9 Y; w/ i - *
5 y; S$ B" Y( |! _ - * This program is distributed "as is" WITHOUT ANY WARRANTY of any- T" |4 |+ @- @& R' y/ m; j$ t
- * kind, whether express or implied; without even the implied warranty2 E2 F2 ~# x/ L9 J4 [2 k# S
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the) z$ g- q5 h" I3 d- v
- * GNU General Public License for more details.
9 _$ K) n2 z' k* B% j: r$ i; H3 q - */( \' Q \ J) j! I' h! C' X
/ r- ]7 B3 N) d# L+ j% X- #include <linux/module.h>) N5 G2 D b7 q$ h
- #include <linux/init.h>
6 L1 Z Y C. @' F" j - #include <linux/errno.h>
5 E& x6 R* p" W x8 p - #include <linux/types.h>
6 d: L2 q2 }! R ^4 U- N, Q - #include <linux/interrupt.h>2 H8 |1 w. l0 F) ?+ }
- #include <asm/io.h>
) {1 Z5 n: C. q+ ~. q, R8 z; Y - #include <linux/moduleparam.h>) w+ z# M4 o0 ]( x1 X' Y. T
- #include <linux/sysctl.h>2 `- k3 b% _% F" T7 t9 Y* a
- #include <linux/mm.h>7 n0 |4 ?1 s. |; Y4 X
- #include <linux/dma-mapping.h>4 `: @2 e+ Q5 ^! \( O* o& c) p5 q
- : R! e( w0 v) l: s0 U: x
- #include <mach/memory.h>
$ J3 N# p/ c8 z - #include <mach/hardware.h>0 j7 Z* S4 e5 S* j/ K- @: Y
- #include <mach/irqs.h>* v2 N' a: k) K9 j' m* e# X9 S( i
- #include <asm/hardware/edma.h>
/ J, @) w# q) T/ O, ^8 w" c - : ~5 h L! j, a h. G) P& Z% A' p" m' h
- #undef EDMA3_DEBUG9 U J" U8 q0 r+ D( j7 n4 F
- /*#define EDMA3_DEBUG*/& o- W4 b8 K' l! ?$ K( q. N
+ G+ f) A, E/ F- ~( ]4 L; i- #ifdef EDMA3_DEBUG% E! B1 B' e$ t5 p8 f) `
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)9 a ^& Y) _, }5 x2 a1 Z3 {
- #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
k) [; c9 G: D2 E4 d7 G7 a. j6 d5 n - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
9 E( V% t6 S0 B/ n7 ~ - #else
3 b* O- W' ~9 |* b+ A - #define DMA_PRINTK( x... )
6 Y$ {2 e! @/ [; D5 j/ t- y# F* B7 } - #define DMA_FN_IN3 m7 G [. Z" Z, N9 E6 _( A8 W j" Q( F3 Z
- #define DMA_FN_OUT7 c( S, f; ~) r& V. t
- #endif
0 Y } \6 V# k v
& Q$ I8 h6 H z+ C* V' R- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
6 w2 C3 ~$ Z. Z7 c6 c+ t( m5 @9 h - #define STATIC_SHIFT 3$ ?8 }( d/ G1 v" K6 V/ J7 r) I$ C
- #define TCINTEN_SHIFT 20
0 Z: Q/ G8 T4 @0 e2 x+ ?5 D - #define ITCINTEN_SHIFT 216 w, \8 j+ U- {6 [! k1 `
- #define TCCHEN_SHIFT 22: E) p6 }" E) L0 r$ o
- #define ITCCHEN_SHIFT 23
@) W! |) S5 L4 u - 6 V m9 M: k C, l. z5 P5 \; ~
- static volatile int irqraised1 = 0;
5 y T# q. }. \( s - static volatile int irqraised2 = 0;" I- h1 Y. _3 f- R
; J; F: }( p9 G3 S- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
/ {/ m2 X. e, C! ?% o9 _ - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
6 { P: D' u& X8 V% z ?$ T z - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
7 r% ]. F- m# G3 Y! {8 A* ^$ W* s
1 z- h. |9 f2 t# x0 @- dma_addr_t dmaphyssrc1 = 0;3 |2 P" D9 a. o( `
- dma_addr_t dmaphyssrc2 = 0;$ X7 k- c$ r& y, i- A
- dma_addr_t dmaphysdest1 = 0;7 V1 Q! H9 h0 p' G" a/ z, ^
- dma_addr_t dmaphysdest2 = 0;! A/ g6 I+ K4 R$ r+ B: F
- / G0 y( G0 F8 Y& _+ l
- char *dmabufsrc1 = NULL;& j- \ n# a* l: x( y
- char *dmabufsrc2 = NULL;
/ l0 U4 z# C; b; ]4 Q7 J8 | p - char *dmabufdest1 = NULL;6 S: r) ?; L; i) c5 E$ ^& p; r
- char *dmabufdest2 = NULL;
1 K- A9 D% b! S( h! ^9 c - ! X* H+ L: V2 }5 [1 _5 {) T3 _7 E
- static int acnt = 512;
+ ^& X2 Z$ b9 A0 C4 Q' t) |% e - static int bcnt = 8;
1 a/ Z3 `1 T1 @ - static int ccnt = 8;0 E: Q8 n9 S+ o2 Y) K
, \ b: G C3 D9 Z- module_param(acnt, int, S_IRUGO);
( l5 C; |$ ?5 E - module_param(bcnt, int, S_IRUGO);
, w5 f, i- B0 u9 S - module_param(ccnt, int, S_IRUGO);
复制代码 ( y2 m5 u) X3 F# l' A
8 @, A! n- c- t+ X2 n9 N/ K
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用& ]" f; K+ I/ O- U8 v6 ]# j3 d
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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。4 y% b4 y+ E4 \. W2 w3 t4 I; ?. @
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
1 j4 M# M: O6 J2 I1 q# M+ D- L s& j) |- D% x# j6 M
& {4 D1 Y2 }2 l$ G" G |
|