Re: timeouts on USB ISP programmer

From: Tomek CEDRO <tomek_at_cedro.info>
Date: Fri, 08 Apr 2022 23:39:51 UTC
On Fri, Apr 8, 2022 at 11:02 PM Axel Rau <Axel.Rau@chaos1.de> wrote:
> Am 08.04.2022 um 20:39 schrieb Tomek CEDRO <tomek@cedro.info>:
>
> Is it possible to disassemble your interface and take photos of the
> electronics inside? We need to make sure what exact chip is inside :-)
> https://www.chaos1.de/downloads/diamex_photos.tar.gz

This is not an FT2232H based device this is why libftdi could not reset it :-)

What I can see is from the photo:
1. 74HC125 Quad Buffer Line Driver [1].
2. STM32F042F6P6 ARM-Cortex-M0 MCU [2].

As stated on product website [3] this Diamex-Avr-USB supports STK500v2
and AVRISPV2 protocols. Details on internal dip switch configuration
and available functions is provided in product documentation [4].
Documentation does not mention Debug, only Flashing.

From the default avrdude.conf we can read that AVRISPV2 programmer
also uses STK500V2 protocol. There is no VID:PID provided in STK500V2
programmer definition so there may be some autodetection mechanism
implemented.

Just try `avrdude -c stk500v2 -p 85 -vvv -t` :-)


It also matters on how you connect to the Target AVR - is it already
powered on some working board or you are connecting to a "bare" AVR?
Also what is the Target i85 or t861?

From the configuration of your dip switches it looks like you are
providing 5V from the programmer to the Target, so you are connecting
to a "bare" AVR..? Both ATtiny85 [5] and ATtiny861 [6] are up to 5.5V
tolerant so it should not burn them "alone". But if you are connecting
to some board with other components it is critical to first verify
what is the acceptable maximum voltage that components can work with.
Old electronics used 5V. New electronics use 1,8..3.3V. If you provide
5V from the programmer to the board working with 3.3V or 1.8V you can
burn the board components. If you use some bigger board with its own
power supply both dip-switches should be in position OFF. VCC
connection from Programmer to AVR does not seem required. Here is an
extract from Diamex-Avr-USB documentation [4]:

Switch position for normal programming in user’s switching= both switch OFF
If voltage supply of the target is needed.
For a single AVR controller only without own switching 5V are required
(for example Diamex program
adapter/pivot lever) 1=on 2=on
General: 3.3V max. 120mA, 5V 150-500mA. Depending on which computer is used.
Switch 1 off= target voltage off/on, switch 2 off= 3.3V / on=5.0V. The
programmer doesn’t need a
power supply from the target for the programming operation.

Long story short:
* Put both dip-switches to OFF if you use external board (no VCC
connection required). They may stay ON if you program "bare" AVR (you
need to connect VCC, SW1=ON, SW2 OFF=3.3V ON=5V).
* Try `avrdude -c stk500v2 -p 85 -vvv -t` and see of that connects to
Programmer.
* If programmer is connected but AVR communication problems you may
slow down the STK500v2 bit clock with `-B` parameter or ISP clock with
`-i` according to [4] (i.e. `-B 250` will result in 4kHz bit clock).

Good luck and let us know if that works :-)
Tomek

[1] https://assets.nexperia.com/documents/data-sheet/74HC_HCT125.pdf
[2] https://www.st.com/en/microcontrollers-microprocessors/stm32f042f6.html
[3] https://www.diamex.de/dxshop/DIAMEX-USB-ISP-Programmer-Stick-fuer-AVR
[4] https://www.diamex.de/dxshop/mediafiles/Sonstiges/ENG%20ISP%20Programmer.pdf
[5] https://ww1.microchip.com/downloads/en/DeviceDoc/Atmel-2586-AVR-8-bit-Microcontroller-ATtiny25-ATtiny45-ATtiny85_Datasheet-Summary.pdf
[6] https://ww1.microchip.com/downloads/en/DeviceDoc/Atmel-2588-8-bit-AVR-Microcontrollers-tinyAVR-ATtiny261-ATtiny461-ATtiny861_Datasheet-Summary.pdf

-- 
CeDeROM, SQ7MHZ, http://www.tomek.cedro.info