QG8 PTA4 does not work as Output pin

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

QG8 PTA4 does not work as Output pin

1,089件の閲覧回数
abicash
Contributor III

Hello

 

I have initialised as thus

SOPT1        = 0x00;   // RESET and BKGD disabled

 

The idea is to use the RESET/PTA5 pin as input pulled up to Vdd and connected to ground through a push button switch.

 

Once the switch is pressed , i poll it and turn on a LED for 10 seconds (currently PTA4 is not connected to any LED or transistor)

Now this scheme works with LED connected to PTB5, but with PTA4 ,it never goes high.

 

It does not change state with or without pull up.

 

Am i doing something fundamentally wrong?

 

The entire design is complete and only this small issue might make me change the MCU..

 

Any help appreciated

ラベル(1)
0 件の賞賛
返信
9 返答(返信)

806件の閲覧回数
pauloprecursor
Contributor I

I´m facing the same problem with ...QD2.

I need to use all device pins, and PTA4 is the "chip enable" of a Serial Flash Memory.

In spite of having one 3.3kohm pull-up, and the SOPT1 is initialized with $00,

its output is always 1.

0 件の賞賛
返信

806件の閲覧回数
abicash
Contributor III

Can someone throw some light here?

0 件の賞賛
返信

806件の閲覧回数
Cram
Contributor III

Hi,

Since your SOPT1 sesms to be right, did you check your PTADD init proces? Set PTA4=1? DO you PTA4 shgare any function that may force your pin to be set to 0?

0 件の賞賛
返信

806件の閲覧回数
tonyp
Senior Contributor II

SOPT1 is write-once, so maybe something (e.g., startup code) writes it before you do.  Have you checked that it is indeed written with zero?

0 件の賞賛
返信

806件の閲覧回数
abicash
Contributor III

Hi and thanks for replying

There is no startup code present.

If you noticed my original post, i am using RESET as PTA5 to get a push button status and drive an LED connected to PTB5, so SOPT1 is getting written to 0.

I checked on other QG8 chips but same thing repeated.

I browsed through many threads here explaining this phenomena but each and every explanation is void in my case.

Any help appreciated

0 件の賞賛
返信

806件の閲覧回数
bigmac
Specialist III

Hello,

According to the datasheet for the 'QG8 (refer to Fig. 1.1), PTA4 is an input-only pin, whereas PTA5 is an output only pin (when BKGD/MS is disabled).  All other GPIO pins are bi-directional, as controlled by the data direction registers.  Also see paragraph 6.4.1.2, where it is confirmed that the DDR bit settings have no effect.

Regards,

Mac

0 件の賞賛
返信

806件の閲覧回数
abicash
Contributor III

Hello bigmac

Is there a mistake in your reply?

PTA4 is an output-only pin and PTA5 is an input-only pin as i understand

I can test this by getting PTA5 as i/p pin to control LED connected at PTB5.

Thanks

0 件の賞賛
返信

806件の閲覧回数
bigmac
Specialist III

Hello,

Yes, I confused the two pins.

I also assume that you disconnect the Multilink programmer/debugger when you test this arrangement.  Otherwise there is likely to be a conflict at PTA4 output.

Regards,

Mac


0 件の賞賛
返信

806件の閲覧回数
abicash
Contributor III

Hello mac

I do disconnect the Multilink after programming.

I have now added a 5k6 pullup on the RESET and BKGD pin.

As soon as POR occurs, The BKGD pin goes to 0v and never pulls up to 3.3v, whereas RESET/PTA5 functions as an i/p pin .Here i connect a Push-button switch ,other end of which is connected to ground.Once i press the button, i light an LED at PTB5 and turn  PTA4 (BKGD) high (here no other part, other than the pullup resistor is present).

i find that LED lights but the PTA4 doesn't change state.

Tried this on few other QG8's from the tube , but to no avail.

Is there something fundamentally wrong which i am doing?

0 件の賞賛
返信