Building one's own tangara
#1
Hello, I am making a thread to share our experiences building our own tangara's from the sources.
First, thank cooltech crew for sharing this great project. And thanks a lot Jacqueline for your support so far.

I have assembled two mainboards, and one faceplate.
2 mainboards, because I thought the first one was failed and hope I'd have more luck with the second.
Truth is, I don't : )

Both boards power on, and I can run commands from the console using minicom. But except that everything seems frozen. I can change the display brightness and see the pwm duty cycle change on the ESP32 corresponding pin ; so something runs, but except that the clock signals (SPI clk for example) are 0V. I have a few clock cycles at the power on and then it stops (and the screen is stuck saying it can't read sd card)

I'll continue debugging my connections, but it the meantime : has someone seen the same problem ? to me it is weird that the esp32 stops the clock on SPI. Is there a command to (re)start SPI from console ? has someone experienced similar problem when building ?

Cheers
Eve
  Reply
#2
Hi!

That does sound very odd. Especially the bit where you do see a couple of clock cycles before it stops. The fact that the display initially works also makes me very suspicious of the SD card part of the SPI bus... maybe there's an issue with the SPI mux that sits between the ESP32, SAMD21, and SD card? Although I'm not sure I can think of any kinds of soldering issues off the top of my head that it would cause it to fail like this.
  Reply
#3
Hi Jacqueline, thanks for your reply.
Indeed, I think there is ssomething weird on the SPI mux, the S pin is high and if I'm not mistaken it means that the SPI signals are taken from the SAMD.
Maybe there is something wrong with the PCA8575 that drives this S pin then, I'll check around this one.
Also I don't have a jack plug yet (out of stock when I ordered on Mouser...) and the signal "3.5mm_DETECT" is high.
Cheers
Eve
  Reply
#4
Hi ! Progress Big Grin !
I disconnected the R32 pullup, so that S goes to 0. Now the SD card (and lua ls works) is detected and screen refreshes !
It is still not in the 3D case and the "naked" touchwheel doesn't react. But soon.
Do you Jacqueline or someone reading there have an idea why S stayed high ?
Eve
  Reply
#5
Hi!

Have you double checked the soldering of the PCA8575 pin that drives this signal? There may be a soldering fault there. Another thing you could check is whether the volume buttons work (they should show a little popup on the screen with a volume meter). If the volume buttons are also not working, this could indicate a more severe issue with your PCA8575.

Regarding the touchwheel, the touchwheel *should* respond (albeit with some sensitivity issues) even without a cover installed. The touchwheel sensor IC is on the same I2C bus as the haptic motor. Are you able to get any feedback from your haptics at all? (Assuming you've soldered on a motor).
  Reply
#6
Hi !
I doubled check for shorts to ground / vdd /adjacent pins on PCA8575 and observed no issues. It's not easy to probe though, so maybe there is an issue anyway. The volume buttons work.
I can measure traisn of pulses when I run the command "haptic" in the console, but then I can't stop them until I unplug USB. I think the pulses are not long enough for the motor to vibrate, but there are pulses (and the motor works). But I measure no pulses at all on the motor pins when I use the touchwheel, and also the TOUCH_INT signal never changes (stays 0).
(also, just in case you think it's relevant to add this, the haptic motor is not part of the BOM generated by kicad).
About I2C bus, I could observe clock pulses on SCL when triggering i2c communication with haptic command for example.
  Reply
#7
Hi !
I assembled a second faceplate, and in the process I finished breaking the first. But the second now has the touchwheel working! (I made a video thinking I could share it there)
Now I still have to fix the issue(s) with the mainboard, because as we could expect there are still issues, maybe related to PCA8575: for example, audio doesn't work... Yet!
  Reply
#8
Also, I re, re, re tripled check all the solders and of course you were absolutely right. I Re did the pca8575 and it's fine. Now I need to Re solder the amp and the tps too. PS: I did re solder everything and it works!! I could play music! Just in time for a gift this week end. I need to assemble the case tomorrow. And afterwards, I'll make one for me too. Thanks for your support!
  Reply
#9
Hi!

Can I ask what your process is for soldering the QFN components on these boards? They can certainly be very challenging to solder correctly, and it does sound like most of your issues so far have stemmed from soldering faults on the QFN packages. e.g. even for a lack of audio output, it could be either a fault on the mute pin of the PCA8575, or a separate fault on the amplifier (U1).
  Reply
#10
Yes, all qfn components were not correctly solder.
I used a hot plate (MHP50 and 30). I placed solder wire (with lead) on all the pads with a small tip iron and flu. It may have better to use solder paste but I didn't have access to it when I mounted the boards. I'm novice with heat plates and temp curves for reflow so I just set it to heat at 250°C. Then I put the pc with the placed components on the plate and waited for solder to melt, helping components to get in with the tip of a thin plier.
Then when I saw that all components were bad, I used the soldering iron and binocular magnifier to add solder wire on the pins and pads.
I think the whole process would have been more successful if :
-I was less excited / doing things fast
-took the time to learn about reflow curves
-I used solder paste instead of wire, but not sure
-I'd put less solder (I was careful not to put too much, but it was still too much) on the big exposed gnd pad, because it seemed that the components were too high to touch the solder on the other pads
Your inputs on these issues are welcome too. I assembled a working one that I'll offer to my partner but will make one for me too and a coworker is mounting one too for himself!
  Reply
#11
It sounds like you've worked out a decent approach then! All the advice I would give is advice you've already worked out yourself Smile

They can be a very frustrating package, but I'm sure you'll get them all sorted soon!!
  Reply
#12
Yes I did on the first tangara that now works well! (and is so cute!)
I'll fix the other board I assembled too.
When mounting the tangara in the case, I have problems with the volume buttons that stay on sometimes, but if I solder the button more on the inside of the footprint, it will be better. (next week, though)
Now the tangara is in my previous phone box, wrapped in gift paper!
Eve
  Reply
#13
Disclaimer: I am not a native English speaker. The following text uses Google Translate. Please ignore some strange expressions. Thank you.

Hello, I am also building my Tangara from scratch. My soldering (should) be very successful, but I seem to have trouble with the firmware. Here are a few questions I encountered that can be answered?
(I use OpenOCD with a daplink to flash co-processor)

Q1: After downloading the bootloader firmware to the co-processor through swd, can I directly burn the firmware to the ESP32 through the USB-C interface of Tangara?

Q2: If Q1 is not possible, is there a more affordable solution for falshing firmware than Jtag?

Q3: When burning the firmware of the co-processor, I encountered some strange prompts, such as "at91samd clearing lockup after double fault". Does this affect the use of the co-controller?

Q4: Is there a tutorial on burning the firmware of the Tangara controller from scratch?

Thank you very much.
  Reply
#14
Hi! Welcome!

(2025-01-01, 05:04 AM)Hwenray Wrote: Q1: After downloading the bootloader firmware to the co-processor through swd, can I directly burn the firmware to the ESP32 through the USB-C interface of Tangara?

After you have loaded the bootloader firmware onto the SAMD21, you will need to load the main SAMD21 firmware (https://codeberg.org/cool-tech-zone/tangara-samd-fw). This can be done over USB-C. Once you have done this, you can also burn the firmware onto the ESP32 using USB-C.

(2025-01-01, 05:04 AM)Hwenray Wrote: Q3: When burning the firmware of the co-processor, I encountered some strange prompts, such as "at91samd clearing lockup after double fault". Does this affect the use of the co-controller?

Unfortunately I have not seen this error before. It could be an issue with your SWD connection. Please double check that your wires are solidly connected!

(2025-01-01, 05:04 AM)Hwenray Wrote: Q4: Is there a tutorial on burning the firmware of the Tangara controller from scratch?

Once you have flashed the SAMD21 co-processor's firmware, standard ESP32 tools will allow you to flash the ESP32. We do not have a full tutorial on this, but it should not be too complicated. This document may help: https://codeberg.org/cool-tech-zone/tang...UILDING.md

Best of luck with your build! I am happy to help you however I can!
  Reply
#15
Hi Jacqueline,
I just saw in the schematics that C17 and C19 of the audio amp are marked to not be mounted. Why ? I think I mounted them on the tangara that is alive.
Thanks for your time
Eve
  Reply
#16
Hi! Those capacitors limit the amount that very high (far beyond audible) frequencies signals are amplified by the amplifier. We thought we might need to include these capacitors for EMC compliance purposes, but they didn't end up being needed. It's okay to populate them; there should be no impact on how the device performs either way.
  Reply
#17
intersting, thanks !
  Reply


Forum Jump: