Chip123 科技應用創新平台

 找回密碼
 申請會員

QQ登錄

只需一步,快速開始

Login

用FB帳號登入

搜索
1 2 3 4
12
返回列表 發新帖
樓主: kolong
打印 上一主題 下一主題

[問題求助] PLL 的實現方法?

[複製鏈接]
21#
發表於 2007-6-10 21:50:08 | 只看該作者
... 這樣說吧
2 {, i- W0 W; ^3 v% {7 J& \如果有 PIXEL CLK 就用它除頻
/ n9 U. E" f, H5 A/ G如果有 HSYNC 就用它倍個幾次
! B6 Z. R/ w: O; v/ e7 X
' t& `; K$ z) I- j. K& O因為 PIXEL(DOT), HSYNC, VSYNC 之間有一定的倍數關係
" W* M7 E8 }7 n4 D, m/ @5 f0 x) K8 ]1 _0 \$ j
   640x480@60Hz => 25.175MHz (39.7ns)1 y/ v, B# ]/ a3 [% x
   DOTx800=HSYNC, 39.7ns x 800 = 31.469us, z: }; h, v& }& A& ]  G; s! t
   HSYNCx525=VSYNC, 31.469us x 525 = 16.52ms (60Hz)
3 }4 Q+ L2 ?$ P9 I. C所以這樣的CLK一定會和VSYNC同步 (詳見VESA Monitor Timing SPEC)
7 \* L0 J- {, g/ ^' W$ a" F) Y
) v3 {4 q( K$ u. ^接下來如果要VSYNC時不出CLK.. 那就用個AND閘吧 (看你用哪個MODE, SYNC有High或Low), Y6 R0 d0 V9 ]4 b: K9 P$ T$ t$ B
# g& x5 D! e  ~/ L- L* z
還是我想的清況和你不同呢?
22#
發表於 2007-6-11 15:02:01 | 只看該作者
這樣子做出來的phase error會很大也, 要先看規格的要求一下下
23#
 樓主| 發表於 2007-6-17 11:12:57 | 只看該作者
原帖由 tommywgt 於 2007-6-11 03:02 PM 發表 2 i5 x  c- f( ^& Z0 s( g; l
這樣子做出來的phase error會很大也, 要先看規格的要求一下下
( v! T2 d$ o1 |# ?

+ ?8 w: N* c) e* b% U5 C! O
. Q% j& i, z! m% O8 d# z) q, J, Z; F" ^" K' D" E5 }% q
嘿嘿....沒錯..
; T0 G2 M# e( s1 x- }+ h9 a8 \9 R所以我現在還是用60hz去產生600hz..
1 j# s! N: a  d: J6 @5 z+ z另外一個原因是因為客戶只會給我60hz的訊號啦...
24#
發表於 2007-6-20 13:39:55 | 只看該作者
不過我還是覺得也許會有更好的方法來設計這個東東的, 所以才會說介紹個人給之類的...哈
25#
發表於 2007-9-10 06:26:03 | 只看該作者
//可直接透過synthesis  tool用於PLD,FPGA不可 LUT delay則要採其他方式。
$ t6 S, D5 S, K2 u" ]7 i//所有註解都要保留
: X4 b) ~4 ^: T) k  u' R
1 a- R4 G, \/ V! |  \' j1 G9 Q! ^`timescale 1 ns / 1 ns
0 u3 ?; W, t% s. [* K. j: q1 cmodule xclk(sclk,ena,set,outp);
0 g9 Y$ K! |" ~, L5 f, @+ n1 k& ~9 [/ ?$ p3 Q
- D, E9 o4 {* e# w% n, Q9 J
7 l- H1 E' [% ~# f' P) c
input sclk,ena;( \; p! G: p! p& ~4 G
input [1:0]set;
) m: M+ \# C) ^9 d" w% _, _" I! loutput outp;
7 O. w0 D. r  w5 @. ~; s" n4 y5 |! }% C, P: }- O
wire outp;- {+ s( ^9 o* m7 x5 t* @$ {
6 b- }. U; X2 F! c
/ s, S2 T( y( x

: g) G! l- w3 u  s/**** Node preservation for nodeA **************/
: |1 T: I7 i5 ^6 h+ i0 o; ?, g% G4 o. j% O

0 J# F- h( ?; `% A6 |2 P4 w! D! p//exemplar attribute nodeA_5 preserve_signal true' A7 G3 F8 f+ r$ b- H
; E6 }& T* y; d
//exemplar attribute nodeA_4 opt keep
$ D& F; i5 ?5 @  e. i  E' m( b1 b) ~; m1 y' \8 Y
/**** The following comment form also works ****/
$ g/ [+ }" T% ~9 y3 p
, x* n. t% L1 C9 I, }3 y) w3 h//exemplar attribute nodeA_3 preserve_signal true( M+ l: U& S, }# X% S

* [9 w8 W/ ]/ o; O//exemplar attribute nodeA_3 opt keep
- ?! H1 D  ~7 @  U% q. U* y
! _/ z5 G2 M7 C  p4 _2 K/**** The following comment form also works ****/
$ D; Y/ m' X. K4 f. H1 m% \( q
; \. W) v1 d1 C) s% ?4 A/ P5 t+ ^//exemplar attribute nodeA_2 preserve_signal true2 S! i4 [5 R7 o9 S8 b. O9 d
4 S9 W9 d/ F9 @( G9 P- _" J
//exemplar attribute nodeA_2 opt keep
5 B2 [' u" A$ h; ^+ Y% ]: c. l/ q: p. k+ {$ [( M, v
/**** The following comment form also works ****/
, O, t& g. a' {7 z. A- H+ E* O5 S
//exemplar attribute nodeA_1 preserve_signal true+ f! P# Q% J/ T7 i% Q& k
- b0 Z0 A' E2 g' o+ B
//exemplar attribute nodeA_1 opt keep5 r! z7 [2 F5 G2 p  C! D0 a0 h# c

1 A4 p/ e& o+ f' i: z# l
, ^! I0 `! w: }/**** The following comment form also works ****/$ g6 _9 s0 L; r* e6 ~% e$ X
* y" ~6 x# I% O
/*exemplar attribute nodeA_0 preserve_signal true7 ~! Q& j* ?8 Q6 t, @
4 D" E0 k1 C3 ?7 b
exemplar attribute nodeA_0 opt keep*/
/ Q) O3 n, w( ]) _
( S1 L% v! |- D
+ j; ~& v3 i# A4 @6 V
9 p$ Y( X5 R+ w5 [& f1 M1 u& a
' H6 P2 w/ ]: {$ s/ k4 M3 P
1 h2 [4 U6 {: e, t" T; C$ e, I, M7 v  |8 k( q" ^; V4 I
& G+ R: U  f3 k

( U9 S: Q! u/ W1 Y3 b& ]3 I& ?9 C0 l( T

' j& ], d$ o* G3 R7 Owire nodeA/* synthesis syn_keep=1 opt="keep"*/;
5 V+ x, L! U) c! p6 R4 ?8 Ewire nodeA_0/* synthesis syn_keep=1 opt="keep"*/;7 ?3 ^& p" i$ `( m) \
wire nodeA_1/* synthesis syn_keep=1 opt="keep"*/;
  L! y8 f( A0 s6 Bwire nodeA_2/* synthesis syn_keep=1 opt="keep"*/;
7 J- z7 j! \5 r' T$ `- cwire nodeA_3/* synthesis syn_keep=1 opt="keep"*/;
; M: R. [% ^' n- K) l: P9 ^, Dwire nodeA_4/* synthesis syn_keep=1 opt="keep"*/;
0 u5 O5 O+ o% d+ O& K0 k  ^
8 C* w' ]) u% N: g: Sassign#1 nodeA_0  = sclk & ena;
+ F7 y& ?) p6 X6 n$ x! z+ p" l7 _- M1 ~/ b% F2 |
assign#1 nodeA_1 = ~ nodeA_0;
; W# {' r0 G) b, N+ v2 ~% D  Yassign#1 nodeA_2 = ~ nodeA_1;
. i" P: j7 J* O( C! A) N- oassign#1 nodeA_3 = ~ nodeA_2;4 b& e2 [0 f- @- t- o5 N! U
assign#1 nodeA_4 = ~ nodeA_3;
: c; e- p  ^: K, ?6 H) F8 P6 V6 j. D2 \" Q: Z
reg xout;
7 j+ H& i# A/ R7 Q1 _2 Y' @& b, P* k1 O8 F- z0 l4 E6 @( a
always@(nodeA_1,nodeA_2,nodeA_3,nodeA_4,set)2 i6 h. j, |3 ]  ]$ y2 g
  casez(set)
2 v9 x( X; z( f3 h9 e    1: xout =#1 nodeA_2;
; z2 w) S* d3 L& Y    2: xout =#1 nodeA_3;
5 Z$ M2 r* R$ i- f% {  U    3: xout =#1 nodeA_4;
) ^# R  s3 y- {2 p# W    default: xout =#1 nodeA_1;
9 ?& k5 e; Q8 t  }  endcase% J0 x+ A: Q" O9 C
  5 f9 \% {3 b/ l/ P4 X5 j% |+ R+ |7 D
assign#1 nodeA = xout;
( Q% A" Y& w& a: B$ R$ s& |assign#1 outp = ena ? nodeA^sclk : 1'bz;
( ]# w4 i4 x1 R: f, `5 [
( F8 e' H- R8 V( I: {9 R" f, Aendmodule
1 E% u2 B9 x) Y, p4 q; O5 [9 X) t! z; \& \; f$ G) L
- g. ~4 q7 I  s* z( i0 j" U* R

- S" J8 [/ T7 O1 ~( |: G`timescale 1 ns / 1 ns* W+ {* K! i) ?; j: s$ e
module xclk_tf();" P3 a' s3 n3 R8 f5 K. K

  Q% O" J) W: H9 z! {// Inputs" h- t1 S) w- [  T: A/ f
    reg sclk;9 w. u# f+ |" B1 ^: I. s
    reg ena;
# l1 B5 c1 l% K' N    reg [1:0] set;
; l) `$ N1 L# s! q4 q. f$ j' \6 R& ]3 l

/ {8 N( U7 a4 E1 a. q9 |5 [// Outputs
( y3 m( F' G; d  x4 E7 ^    wire outp;7 N" j' m% ~* x
- P+ h2 |+ x% _7 u0 f

' H# ]9 a- |* a% c& U- D
. S1 y8 Y0 {( k, ]5 K% B    xclk UUT (
& v3 m( ], q" X+ S0 R3 E        .sclk(sclk),
' {( D8 A1 w2 \' z/ U        .ena(ena),
" v. o* _( P( S) i/ a. ]: K  M        .set(set), 6 _. I$ f& P+ {* \0 l
        .outp(outp)
# f1 h* ^) V( d3 z" }3 Y/ E0 ]        );
6 H6 x1 ]# T& d/ l. ^3 @8 ?, y$ p: M& t. E# n
" U( Q/ U$ c4 L; ~" ?2 _) \

. u$ `0 Z. K/ q9 B    initial begin
1 @- i: w/ `% i2 P$ E7 m! A1 ~            sclk = 0;/ \1 N+ H# r' ?# j( A/ w, t
            ena = 0;
. @6 [) J( ^0 E% Q  O$ p5 F' y3 K            set = 0;4 h0 R: e# k4 M6 G$ s. {. A
    end/ S2 ^+ {6 J' B8 l5 N! j" E3 m- N
: D7 ]2 R& J' F$ Q& s3 ~( ]( ?
& a" j4 W3 k! ~3 J! m+ V; _
always# 5 sclk = !sclk;  x6 l, \1 g7 F" }

: o& \! c$ \+ b/ T: y  yinitial begin
5 P2 L+ x$ \! }8 `$ A2 a8 [5 u        #1007 v( T# A% E1 ~  }3 Y! W
          ena = 1;; s' f( `: n2 s0 o# X# d6 k& |
        #2000 , ]# L* K: v3 W9 [
          set = 2;& w2 j, W/ B" z% H7 n' g0 K
        #2000 - y* U- p. H: ?: Z
          set = 3;7 l9 |3 j, u) x5 L2 L; H* K1 `
  #20009 b1 f, Q8 y8 e9 T# R  L3 `5 x
  $finish;
1 _. {, c, d6 Z/ `end; N! A) N6 J" c# J
endmodule // xclk_tf
26#
發表於 2007-9-10 14:49:50 | 只看該作者
這個有趣了9 W: o' l+ {& F6 {
有simulation的waveform嗎?1 V$ C% J% ^1 x% L% p4 s4 v
示波器量的更好~~~^^"
27#
發表於 2007-9-10 17:20:59 | 只看該作者
有附 test bench
0 d) y9 a% U/ l' q2 R; Q# k; @確實可用! 已實驗過,但我不會貼圖。, r2 p' I+ H3 h1 }" A& \
只要略加修改即可實現。
28#
發表於 2007-12-24 14:50:48 | 只看該作者
請問一下你是要控制LED在顯示方面的應用嗎??+ ~0 S  y, S: X* y& q! j" O" B
0 z: N" Q2 c1 J( e3 m
可以和你討論幾個問題嗎??
' H. n" ?; X- M) m: v  I( r/ g$ Z  i% z2 s, D$ n# [- W# \
方便留MSN嗎??
& D$ p) e/ p0 j  h5 l) y$ V& b
1 A7 k1 ~# e  R2 ]+ ]5 w9 w感謝
29#
 樓主| 發表於 2007-12-24 16:35:41 | 只看該作者
沒錯...9 Y% M- _, q. s
是要用在LED Backlight的..../ o7 W) ^5 }3 X; X0 G% T
其實有問題可以在這個帖子直接討論..; Z! S6 Z* J8 u
這個沒什麼秘密啦...
4 c8 q% k. }+ s/ h2 a因為我已經申請專利了.....
30#
發表於 2008-10-4 00:04:50 | 只看該作者
嗯~~大大解答蠻詳細低~~~多謝喔~~~小第在研究看看~~~~~~~��
您需要登錄後才可以回帖 登錄 | 申請會員

本版積分規則

首頁|手機版|Chip123 科技應用創新平台 |新契機國際商機整合股份有限公司

GMT+8, 2024-5-18 08:37 AM , Processed in 0.116514 second(s), 15 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回復 返回頂部 返回列表