找回密码
 注册
关于网站域名变更的通知
查看: 309|回复: 2
打印 上一主题 下一主题

关于FPGA的DS18B20模块的时序问题,感觉一点错都没有啊...

[复制链接]
  • TA的每日心情
    擦汗
    2019-11-19 15:26
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-7-5 14:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x

    求大神指导一下到底哪里错了,已经调试了三四天了,不管怎么调temp的值都是0.。。

    module DS18B20' s$ F* ], g  e' |
    (
    0 w. n2 s7 r! ACLK48M,
    1 \3 r$ u) [0 w//RST,& T) p3 `/ F1 i! ]
    DQ,
    6 L2 o+ y) e& |2 W/ P. Btemp
    ( @2 \0 z; U% s);
    # [$ [# F9 D1 \# u/ ?1 l( f0 Y//Port declaration
    ( U2 L. k' K1 |8 L( ninput CLK48M;
    % @5 I1 b8 q1 ~* [//input RST;
    ) e; |- U- E2 |3 T8 a8 p7 i- Jinout DQ;
    7 A! W4 [9 d  `; ]! aoutput [11:0] temp;

    reg [7:0] Cnt;) e2 k( q: D" M2 \
    reg clk1MHz;

    always@(posedge CLK48M)7 S6 p6 v7 e/ \8 f& }0 e9 ^7 H
    begin0 z8 E1 L2 N/ P! e
    if(Cnt==8'd23)
    , W" v+ {8 ^& ]  }2 x( E0 l# ^1 n: Tbegin
    , T: m) p2 e; sCnt<=8'd0;4 Y9 H: u! p) V6 }
    clk1MHz<=~clk1MHz;
    $ }0 B6 B& @+ D9 B, W& ^/ u" e% qend
    7 {8 o) s+ |9 F9 \6 `/ m3 a, telse# [1 b. A. B* w2 P. H# N
    Cnt<=Cnt+8'd1;
    ' f+ L" G1 v1 C# Q/ H) a' G' Mend8 v6 {2 ^1 p3 `( k7 Z/ T

    * L9 R3 }2 Y8 `2 Y7 x; X9 bparameter IDLE = 11'b000_0000_0001," L5 @5 ^9 U  x! u, H' E! T
    DO_RESET = 11'b000_0000_0010,  p* S& }1 ]/ w' _8 U; w) y
    CMD_CC = 11'b000_0000_0100,, Y1 M, C/ n7 Y
    CMD_44 = 11'b000_0000_1000,/ D% t. q5 q2 t: O0 }! x: m
    CMD_BE = 11'b000_0001_0000,3 }- }3 F; x% T5 B6 ?2 l
    WRITE_BYTE = 11'b000_0010_0000,: M, r2 {; f' s1 t: W
    Write_High = 11'b000_0100_0000,4 J; G9 p" G' n+ ^1 j
    Write_Low = 11'b000_1000_0000,
    + u+ Z4 m/ s4 v) s3 U' A0 @WAIT_750ms = 11'b001_0000_0000,# v4 \& L, E! o) I% y! u
    READ_BIT = 11'b010_0000_0000,. Q. N1 k4 [! h5 z& d0 L
    GET_TMP = 11'b100_0000_0000,
    % Y+ N% \9 m5 k; F  `WAIT_4MS = 11'b100_1000_1000;
    6 s5 ~% J# w$ ?  K5 E  ]//-------------------------------------------------------------------  s: G+ r: G* ?$ I. B+ T& D- B) y
    reg [10:0] state;  H! I, I: Y. H9 D
    reg [31:0] counter;
    " l# Q6 y0 y) N/ Sreg DQ;
    ; u2 E- [& o7 J1 F+ o: |0 Y7 Mreg [7:0] write_byte;//中间寄存器,保存主机要写的指令字节  n- c" j. X  h& U( g- E
    reg [3:0] write_byte_cnt;
    1 C& x0 O& S5 S+ c; X* N! mreg [1:0] byte_flag;/ C  c* H6 H% I# S7 g
    reg [3:0] read_bit;
    % {, T2 ?$ c! {1 Mreg[11:0] temp;//12位温度数据/ [, m& M0 t0 O& P0 I- n& E
    reg TMP_bit;

    always@(posedge clk1MHz)
    $ n; c) O: I- ^  t4 \: pbegin. r" I3 y' O" ^. _
    case(state)4 r, d# T( p' s" o* I( H* b
    IDLE:8 ~; R/ s/ ^( s0 W" w
    begin
    * W. R! z" \6 C8 o7 I2 r3 m" tDQ<=1'bz;//空闲状态释放数据总线,由外接上拉电阻将DQ数据线置高0 T  X3 i/ r7 [% M4 W1 p. Q' M
    counter<=0;8 v: y2 E+ _4 W. \, Q( j5 H
    write_byte_cnt<=4'b0000;$ p! A+ z8 b' {9 V2 L1 U, s. w
    byte_flag<=2'b00;+ u: q: m  ?6 l7 d- S: s0 }
    read_bit<=4'b0;
    8 L& w  I' U$ f. ?" nstate<=DO_RESET;$ Z: P2 y- X) z
    end
    3 G! g  j6 \1 S" Y" vDO_RESET://主机拉低数据总线持续至少480us,然后释放总线
    # g) L2 \* p. t6 G% E7 A: ]begin
    - T2 o; H2 A; h3 n2 tif(counter<=480)
    : U$ C4 P6 F" Y: ^) rbegin: T' O! G5 h6 T' w! y6 y  _
    DQ<=1'b0;//拉低数据线480us
    5 a$ r% t! |, Xcounter<=counter+1'b1;
    6 j5 }8 `7 r$ Xend+ m6 o3 i; ^! K+ I% x! X  X9 O1 Z
    else if(counter>480 && counter<=780)
    % C' j4 q- b  {begin
    4 y, o. X  x; q  k; F0 aDQ<=1'bz;//释放数据总线60us+240us=300us) e' s3 x: s. U4 }7 H# T9 c
    counter<=counter+1'b1;3 R; H* L9 E9 ^2 t3 O! ^& s
    if(DQ)//检测从机是否发送Presence Pulse(持续60us~240us低电平)
    ( Q( s& i, I* i1 b3 z( k3 |# vbegin
    # @# u3 [: F* I  Hstate<=CMD_CC;
    9 k" `5 }! C( W( [counter<=0;8 u5 U# M2 \' J5 k+ }" U
    end
    5 S, e, S. ~5 E* E0 {1 J& ?6 Melse4 Y, u0 M3 R) r9 C" S& D1 [
    begin
    * m; o, G0 C5 Q3 y6 R8 z+ D4 D7 cstate<=IDLE;: y5 J' I9 Y5 R3 k; [+ F
    end
    - k" m2 }8 r" }end
    ' p8 t# y# F$ Bend0 c1 Y) @  ?. p: g/ M0 W& z
    CMD_CC:
    , B7 C6 E' q: S9 [; Y) o1 Ebegin
      X" `% u+ C5 v4 [4 n" uwrite_byte<=8'hCC;2 L' D; G8 Q: ]* [! D
    state<=WRITE_BYTE;& g& p# W6 y7 E
    end6 l3 @" W) o& Q# m: [7 Q
    WRITE_BYTE://写指令字节,由低位向高位依次写入从机
    " N% p4 q# U8 C3 u+ E$ H! M' |begin
    : c; W( ]8 t/ N; T( N7 Wcase(write_byte_cnt). u( g  Q2 d. S! y- j, b  r9 E
    4'b0000:& S: _7 p+ a! b. ?" Y5 W, t
    begin2 t1 j# M1 `. ~
    state<=write_byte[0]?Write_High:Write_Low;# V- \% [3 y& r1 v4 \
    write_byte_cnt<=write_byte_cnt+1'b1;
    7 P$ G$ q, N6 zend
    % |5 G0 i! D- O4'b0001:
    . l$ e/ q5 ?( ]; D8 S3 Ubegin4 k4 r1 U% g- D+ t( V, M) X' n
    state<=write_byte[1]?Write_High:Write_Low;
    ( y; |3 {) P' G6 y2 S  Twrite_byte_cnt<=write_byte_cnt+1'b1;; b  S0 U7 W7 i6 q
    end! A) b+ {1 C8 M- X- l8 }
    4'b0010:
    $ z! R7 |4 l5 Q7 ~# J) \begin
    0 @/ b; S0 x5 |, p; D4 `, ystate<=write_byte[2]?Write_High:Write_Low;
    ( L, k: J2 _& i- E& C2 ~& f# Iwrite_byte_cnt<=write_byte_cnt+1'b1;% N* g5 d- ~& p
    end) ~3 k% F7 w2 f. z
    4'b0011:
    , S! {, L% V7 b/ |* Lbegin6 ~, \  Q: g( U% ^
    state<=write_byte[3]?Write_High:Write_Low;
    1 t/ ~2 M) c* h  y5 t! M2 Awrite_byte_cnt<=write_byte_cnt+1'b1;
    # ]$ I3 K" L+ Y+ A# q+ \: U! b$ ]end
    : P7 N' @8 G9 E* X4'b0100:
    4 B7 x& w1 B: X5 c; `% J8 \begin
    2 S2 _  F# U# hstate<=write_byte[4]?Write_High:Write_Low;6 m, z) `' ^9 h, b0 Z# q' J
    write_byte_cnt<=write_byte_cnt+1'b1;; W5 l  I! k/ {4 J2 h
    end; Z! V) n1 V+ I& I3 n6 n
    4'b0101:/ |4 G. w8 Z7 p, |" J
    begin  P! k' b, ~* r. C4 Y6 e$ V
    state<=write_byte[5]?Write_High:Write_Low;$ q, C. b1 o$ T' R- V4 W
    write_byte_cnt<=write_byte_cnt+1'b1;
    & x$ ^% p$ W$ qend0 i( t4 Q9 M2 w
    4'b0110:, a7 |& @; ]: t" x
    begin- w4 E6 P: i; @
    state<=write_byte[6]?Write_High:Write_Low;2 J  E8 x# e" O$ v+ j3 w
    write_byte_cnt<=write_byte_cnt+1'b1;0 D! y! Z0 k9 E/ F$ ~) J
    end
    3 b8 Z# M( O& X2 m4'b0111:
    ' t: e+ J1 ^/ }) h4 rbegin8 v: A8 w! x" Y* t, @
    state<=write_byte[7]?Write_High:Write_Low;
    / ^( t4 Z) z$ @$ F3 ^2 {write_byte_cnt<=write_byte_cnt+1'b1;! c* u6 W' d% |' J+ F+ x# {5 L
    end4 X* \* e( L9 T' U. {4 ?) s
    4'b1000://8bit字节写完后在此处进行状态转换
    0 p4 t- @+ u0 D  T/ ?( pbegin' d4 A# K# B4 s+ R* L2 w
    write_byte_cnt<=4'b0000;; ]; f  C2 D9 o0 s/ V6 W
    case(byte_flag)
    $ [* p9 U( j; e3 J% B2'b00:" H  f6 T6 e8 z. T2 |) T# }
    begin7 b' O) r) x8 k% H5 V5 u
    state<=CMD_44;6 o& o; q6 x" ~3 _, I
    byte_flag<=2'b01;
    / a4 |, K. }; X( [" S, z) W9 rend
    + ^# y& D- h+ V8 w1 G2'b01:
    . u6 k* U; w; f! P0 zbegin
    9 @2 N+ u4 k7 b$ N# _0 _5 Z1 rstate<=DO_RESET;
    6 Q( R5 c" j) G7 c+ U- r( r0 J3 |byte_flag<=2'b10;
    ) A) H+ K' r' }( D, Mend
    3 h% x6 o* i; y* g& T6 o9 E8 E2'b10:  h, b2 E- E7 B. m; {
    begin
    4 R; `& k- B/ B. J0 v0 X+ h$ Dstate<=CMD_BE;: a1 t. s, `0 W0 O
    byte_flag<=2'b11;
    - N) r; N/ c* {, r" i- z2 fend2 l* v  c6 R! M- n2 }
    2'b11:
    4 S6 r! Z! ?6 Q& S& d8 O! ]begin
    ' |3 ^; {) ^$ h/ u2 ?2 `state<=GET_TMP;
    4 y5 l$ v( T) f$ j7 Jbyte_flag<=2'b00;
    ! X0 O0 X( m) n& k- |$ h% N- J8 Yend! y& c* P7 @! T4 t( k+ d% c
    endcase+ z! s9 E' l( ?. }8 d0 ]( y
    end * G. H+ ?% h' K9 Y! _
    default:write_byte_cnt<=4'b0000;" _7 p8 i5 g+ L- P# R+ p; b" R+ ~! F
    endcase' x6 f+ C0 h: |4 u* f8 F
    end8 d! _% r+ Z4 l/ w
    Write_High://写‘1’时序:主机拉低数据线1~27us,然后释放数据总线30~数千us.
    7 C6 W- A/ j* i0 _+ k4 Tbegin/ J( U4 _* T+ h& p6 V
    if(counter<=8)//拉低数据线15us(至少1us)" B0 x( |/ J* \9 v/ B- i! B
    begin7 W6 x( i6 ?" {, I0 L6 d
    DQ<=1'b0;' h; d! W& d& g* O6 ~5 N
    counter<=counter+1'b1;
    & ]1 r5 L$ ?8 a/ o$ y, [end* C. {+ `/ g' }, a+ i" `3 s& j
    else if(counter>8 && counter begin: Z' I* W3 N. e* F. A
    DQ counter end
    ( A/ J- Y) X- n8 jelse " v7 T% @, R1 K' c5 |. b! V
    begin8 F. m6 ~" p5 W- `4 P) [
    counter state end- p8 {0 V, G, M  _& _
    end
    7 y/ ~" p1 i/ k- w# L. B: c( oWrite_Low://写‘0’时序:主机拉低数据线30~227us,然后释放数据总线1us~数千us.+ Q0 m' u+ N# v% T! i9 b
    begin
    0 G0 J- ~1 S2 O( uif(counter begin
    ; k2 O: l/ N" a5 T# z8 `( P# Q; P& VDQ counter end
    # @- v# i, z( m6 n/ _% lelse if(counter>78 && counter begin
    0 l8 i5 t' o& c8 S$ I7 wDQ counter end
    6 x# G8 Y( d9 u) Eelse
    , e( M. |: z7 U, d0 Ibegin
    * h" M: X4 e: D9 _* u* Tcounter state end7 |: q" r& }" i8 s
    end
    . {( _& n, K& y) s( L- SCMD_44:1 |( [. j) f) `  t
    begin8 [2 ~- H5 O; F0 y. c2 `1 x
    write_byte state end
    2 q; @# Z- x$ |/ @8 CWAIT_750ms:
    ! W; J9 q) I1 W  Y$ mbegin8 j& Q! G$ y) z
    if(counter>750000)//实际上只等待几us甚至不等待也可以
    / j6 d; M2 t7 g( ~+ l7 Ibegin. N% H  u) E. s1 g8 F. i
    state<=DO_RESET;9 G$ v( s- K+ p# T& S
    counter<=0;
    * U9 V$ A, h0 F+ Q2 Jend6 x6 T* [* M" P. P# G& d' k3 ?
    else9 e! _& d. x3 p# R
    counter<=counter+1'b1;' Y0 T" }* Z0 M7 \" X
    end' g- L. T7 L9 M3 a. }6 H' i
    CMD_BE:
    2 Y0 G2 V* D# mbegin
    3 g! x  Q8 k  K9 K; R, Pwrite_byte<=8'hBE;
    ; ~! g  x/ L! x9 @state<=WRITE_BYTE;1 g% j" J) [% m8 @+ Z- N( a
    end5 C5 m2 N, H+ f6 A6 y
    GET_TMP:
    * Q& I& |1 H( d! U% R4 w6 |  a# }begin9 O1 }8 F2 l7 S6 Z8 h8 K& X6 b: R# e
    case(read_bit)
    $ L; j' D+ G9 y4'h0:
    7 P4 @* K/ s! ]8 V  t5 J7 ubegin- R0 K( `' m( E- ~: C  G7 a( ~, b9 C
    state<=READ_BIT;% s) Z5 h; U# ~
    read_bit<=read_bit+1'b1;
    # u3 h- S+ @% Dend; M. M7 S+ c8 v3 t$ Z0 W) B5 b
    4'h1:" k0 {- v, N+ m4 |# o
    begin
    - k9 I, A% @% mstate<=READ_BIT;2 B. c; Z1 r. D$ Q8 \! [3 f; }
    read_bit<=read_bit+1'b1;
    . i; [' a# M1 W! Htemp[0]<=TMP_bit;
    8 D3 X  i. c" C% l2 gend+ k& O& T' t  d8 r9 P5 b& E0 i
    4'h2:0 s/ N" q/ ^+ Z- t2 d( q
    begin; L6 N& Y$ H, X. A6 N
    state<=READ_BIT;
    7 f! B# E* z7 u7 qread_bit<=read_bit+1'b1;
    % N0 P) c4 G5 h( P; X( Q* o+ \temp[1]<=TMP_bit;, J7 t2 H; ?2 ?  c8 |+ q
    end" y. L5 u7 Y% i( c6 O) S
    4'h3:4 Z9 s: J2 w0 ?$ v6 u+ t7 `
    begin
    2 r" b+ Y9 x- V. C- `; w  mstate<=READ_BIT;
    : ]  K/ t# R: T; ~; c# ^read_bit<=read_bit+1'b1;
    3 Z" N+ p; n" Z: k! X+ U6 W# atemp[2]<=TMP_bit;
    + y; u, u) o- m% q+ f/ ^! vend; o9 s: f* H% l9 C% x
    4'h4:
    7 k7 Y. H) e: n- W" H$ hbegin
    ! v  z8 E6 P7 rstate<=READ_BIT;5 ?* M2 l2 r/ H2 L) M, [
    read_bit<=read_bit+1'b1;' ^& l- y" N1 M# m0 _4 @
    temp[3]<=TMP_bit;) _! h% O( E2 M/ c# F
    end; `6 {9 z$ K/ ?. ]. {
    4'h5:
    & {& F  z5 G2 `9 N0 wbegin, ~8 v& `1 W2 u( V5 I" D
    state<=READ_BIT;
      z* h+ g% K+ E" Z8 k7 p3 Uread_bit<=read_bit+1'b1;1 A5 x8 D7 O2 s/ U- r2 F8 x1 t+ P
    temp[4]<=TMP_bit;
    4 P! Q) [9 A0 r% g( zend
    " @3 O: b7 K! G; ?4'h6:
    : d4 Y; Y- O. \: H+ [7 Ibegin8 i% |& |6 P/ ^* X  N" U: b- f$ E
    state<=READ_BIT;7 t, S- s+ k$ `) h/ d: _
    read_bit<=read_bit+1'b1;! T6 G& n6 x/ y- x3 N
    temp[5]<=TMP_bit;6 J. K/ D2 j% l( B
    end$ {! f6 v, ?3 i. p
    4'h7:: w" q0 |/ r! W( l6 U8 T- u
    begin/ K% O$ K: Z# r6 K( N; i
    state<=READ_BIT;
    , ~0 I8 N* [' ?, t6 }, w5 ~read_bit<=read_bit+1'b1;+ H6 B) Q- e+ m6 C
    temp[6]<=TMP_bit;; M5 F7 Y  M( P: k7 T' P
    end
    " D; p9 B  w8 F! u4'h8:6 G8 Z' ]8 x' P9 F. f0 @
    begin
    7 M, b3 O5 s5 ]. F0 Istate<=READ_BIT;
    0 l2 n. T3 \0 n. l' Vread_bit<=read_bit+1'b1;* B4 w' `8 a- ?, R, E
    temp[7]<=TMP_bit;9 B- F  e: B% w; F9 [0 K) s
    end
    $ ~, R1 R% w" w- P' ]4'h9:! C; z# c# [- {; }2 i; o5 R1 _+ U
    begin; ]) \) Y' N+ U  ^
    state<=READ_BIT;) k. [3 m5 Q, R* v
    read_bit<=read_bit+1'b1;
    $ m0 ]6 U5 C1 q0 j9 a! [temp[8]<=TMP_bit;
    5 ~3 P! i3 y! ^7 Y( H4 G7 |& Zend
    - e7 q4 p+ m6 B8 i3 J# |4'hA:/ v7 y( T  z6 T6 p- L
    begin
    9 A# _& K9 y/ A7 t6 s0 qstate<=READ_BIT;  g) J8 |& _6 d1 X/ j
    read_bit<=read_bit+1'b1;
      r2 O# H4 {+ V; E  w2 P& z% ptemp[9]<=TMP_bit;
    & y1 ~& O5 O' X+ D8 p. u# v* Lend
    ( E/ _; U' S. W3 r4'hB:
    " j$ T$ L, ]4 ?6 J8 J/ N2 Sbegin# h9 c, C# u  C3 }$ `; b4 j5 f
    state<=READ_BIT;
    0 Q$ `9 K3 a3 Q8 D) [" q9 i' Vread_bit<=read_bit+1'b1;
    , ?& X/ S& n7 d7 L* x: etemp[10]<=TMP_bit;9 E3 U$ ]! G9 O8 ]! C8 q# a. Y/ I
    end8 p3 _( h7 l& \' J- c2 B  q
    4'hC:
    ! A0 O& B( [( z) I1 n; w, Ubegin- x1 c5 e% i6 r- ?
    state<=WAIT_4MS;
    . Y" l8 ~. U( {6 G! {  Kread_bit<=4'h0;
    6 N8 p: H2 O0 N( p& x; Dtemp[11]<=TMP_bit;4 {7 _; J! ^, b5 w) S0 S, k
    end# Q! `- T$ c/ B5 P7 \/ \
    default:read_bit<=4'h0;, I0 Q# {6 K# v: p
    endcase 7 e$ y* _* G1 t; Z
    end
    ) ?. U4 k6 W9 X. L" v6 J0 ^3 E5 vREAD_BIT://读时序:主机拉低数据总线约2~4us,然后释放数据总线2~4us,再读取DQ数据线上的值8 b( E! ]( f7 P1 h$ I1 q; ?0 Y
    begin
    & k6 E% \+ l# F- g/ S4 c5 j4 G) X; sif(counter>=0 && counter<=3)5 W; Y+ t" ]7 K* x  g" Q
    begin- |  v: ]/ Y* z* ^$ E
    DQ<=1'b0;//主机拉低数据总线约5us( }) [5 v3 u( [1 y, n$ \( `: x
    counter<=counter+1'b1;* @, [) I) z- Y3 Z; f
    end
    : o. O* u! k6 c- V( q" delse if(counter>=4 && counter<=7)//最迟必须在29us处释放数据线2 P( N7 @- s0 `; J/ h7 v
    begin4 Y2 v  F$ X+ ]/ m4 E2 h
    DQ<=1'bz;//释放数据总线5us) y: d( H4 P, f& e+ v: L& y
    counter<=counter+1'b1;$ d/ ]6 e0 H' Q  q
    end+ e9 T, @; O' I
    else if(counter==8)8 y  F. R5 v/ ]; @5 C
    begin. I9 L/ H+ v. w% t6 F
    8 ?. d0 D, w9 G5 p. R
    counter<=counter+1'b1;
    6 @- e. J* T/ {; \: h: N; m9 vTMP_bit<=DQ; & A& S( k  B( p3 M
    end8 F, x6 g/ Q1 T" ?* j/ r. o
    else if(counter>=9 && counter begin6 O0 v1 e) X4 e7 \( ]" X
    counter end# U- Y- t5 k6 V: `
    else
    ( Q) A3 D" }. X- v5 Cbegin% }4 v) Y5 X. D" W) U/ `% S
    state counter end
    : V1 D) S7 {' send
    5 E+ ^2 Z! V5 }WAIT_4MS:
    # B# O& h* x; @begin/ K0 m: l: Z. u/ D& k) w! N
    if(counter>4000)7 J/ m/ q& k! S1 x4 O; ^
    begin & g6 {% W9 I, }5 L+ Q
    state<=IDLE;7 E9 E! V" M- O8 p% q; n
    counter<=0;# c& E  v7 j4 S6 w! i
    end
    6 w! m# |) i) J# N; p: [else, w8 y; K; E5 w0 ^" n
    begin7 _  L: ~" z2 w9 H) H$ z, a
    counter<=counter+1'b1;
      h& k9 @, C2 F" H# Uend
    ) A+ e+ l8 l* V9 v3 [end, x4 R1 _% M' @" f( U0 ]" B0 j
    default:state<=IDLE;
    . R9 t3 i# t1 p0 R7 {% ?* Q) @endcase

    end
    " E3 H* L# D( R4 aendmodule


    7 }) n5 X/ M9 _, F# l

    该用户从未签到

    3#
    发表于 2019-9-5 13:36 | 只看该作者
    我也有这问题,请问解决了吗( y5 f( q; w) H
    3 Z& j. G5 {; s# `# ~0 i
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-8-18 06:24 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表