Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

usb connection issues #265

Open
xkonni opened this issue Oct 10, 2024 · 85 comments
Open

usb connection issues #265

xkonni opened this issue Oct 10, 2024 · 85 comments
Labels
fix/pcb Fix request for PCB

Comments

@xkonni
Copy link

xkonni commented Oct 10, 2024

got 2 crkbd rev 4.1, love them, typing on my old 60% is a pain now.

but for some reason the usb connections on both devices are rather unstable on my machines (linux pc, 2 dell laptops with linux). first I thought it was a hw issue, but the second (one from a diy store in germany, one from aliexpress) shows the exact same issues.

using your firmware with the vial keymap. tried some options (remove USB_SUSPEND_WAKEUP_DELAY, increase it, ...) but the devices remain unstable. sometimes they run for hours, then they fail every few seconds.

Could this be related to #229 ?

any help is highly appreciated!

logs:

Sep 29 21:15:06 annoyance kernel: input: foostan Corne v4 as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.0/0003:4653:0004.0058/input/input158
Sep 29 21:15:06 annoyance kernel: hid-generic 0003:4653:0004.0058: input,hidraw6: USB HID v1.11 Keyboard [foostan Corne v4] on usb-0000:2a:00.1-3/input0
Sep 29 21:15:06 annoyance kernel: hid-generic 0003:4653:0004.0059: hiddev99,hidraw7: USB HID v1.11 Device [foostan Corne v4] on usb-0000:2a:00.1-3/input1
Sep 29 21:15:06 annoyance kernel: input: foostan Corne v4 Mouse as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005A/input/input159
Sep 29 21:15:06 annoyance kernel: input: foostan Corne v4 System Control as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005A/input/input160
Sep 29 21:15:06 annoyance kernel: input: foostan Corne v4 Consumer Control as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005A/input/input161
Sep 29 21:15:06 annoyance kernel: input: foostan Corne v4 Keyboard as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005A/input/input162
Sep 29 21:15:06 annoyance kernel: hid-generic 0003:4653:0004.005A: input,hidraw8: USB HID v1.11 Mouse [foostan Corne v4] on usb-0000:2a:00.1-3/input2
Sep 29 21:15:09 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:09 annoyance kernel: usb 1-3: device descriptor read/all, error -71
Sep 29 21:15:09 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:09 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:09 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:10 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:10 annoyance kernel: usbhid 1-3:1.0: can't add hid device: -71
Sep 29 21:15:10 annoyance kernel: usbhid 1-3:1.0: probe with driver usbhid failed with error -71
Sep 29 21:15:11 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:11 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:13 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:13 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:13 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:13 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:13 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:14 annoyance kernel: usb 1-3: device descriptor read/64, error -71
Sep 29 21:15:14 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:15 annoyance kernel: usb 1-3: reset full-speed USB device number 50 using xhci_hcd
Sep 29 21:15:15 annoyance kernel: usb 1-3: device firmware changed
Sep 29 21:15:15 annoyance kernel: usb 1-3: USB disconnect, device number 50
Sep 29 21:15:16 annoyance kernel: usb 1-3: new full-speed USB device number 51 using xhci_hcd
Sep 29 21:15:16 annoyance kernel: usb 1-3: unable to read config index 0 descriptor/all
Sep 29 21:15:16 annoyance kernel: usb 1-3: can't read configurations, error -71
Sep 29 21:15:16 annoyance kernel: usb 1-3: new full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:16 annoyance kernel: usb 1-3: New USB device found, idVendor=4653, idProduct=0004, bcdDevice= 4.10
Sep 29 21:15:16 annoyance kernel: usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Sep 29 21:15:16 annoyance kernel: usb 1-3: Product: Corne v4
Sep 29 21:15:16 annoyance kernel: usb 1-3: Manufacturer: foostan
Sep 29 21:15:16 annoyance kernel: usb 1-3: SerialNumber: vial:f64c2b3c
Sep 29 21:15:16 annoyance kernel: input: foostan Corne v4 as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.0/0003:4653:0004.005B/input/input163
Sep 29 21:15:16 annoyance kernel: hid-generic 0003:4653:0004.005B: input,hidraw6: USB HID v1.11 Keyboard [foostan Corne v4] on usb-0000:2a:00.1-3/input0
Sep 29 21:15:16 annoyance kernel: hid-generic 0003:4653:0004.005C: hiddev99,hidraw8: USB HID v1.11 Device [foostan Corne v4] on usb-0000:2a:00.1-3/input1
Sep 29 21:15:16 annoyance kernel: input: foostan Corne v4 Mouse as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005D/input/input164
Sep 29 21:15:16 annoyance kernel: input: foostan Corne v4 System Control as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005D/input/input165
Sep 29 21:15:16 annoyance kernel: input: foostan Corne v4 Consumer Control as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005D/input/input166
Sep 29 21:15:16 annoyance kernel: input: foostan Corne v4 Keyboard as /devices/pci0000:00/0000:00:01.2/0000:20:00.0/0000:21:08.0/0000:2a:00.1/usb1/1-3/1-3:1.2/0003:4653:0004.005D/input/input167
Sep 29 21:15:16 annoyance kernel: hid-generic 0003:4653:0004.005D: input,hidraw9: USB HID v1.11 Mouse [foostan Corne v4] on usb-0000:2a:00.1-3/input2
Sep 29 21:15:20 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:21 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:23 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:23 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:24 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:27 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:27 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:28 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:31 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:31 annoyance kernel: usb 1-3: Device not responding to setup address.
Sep 29 21:15:31 annoyance kernel: usb 1-3: Device not responding to setup address.
Sep 29 21:15:31 annoyance kernel: usb 1-3: device not accepting address 52, error -71
Sep 29 21:15:31 annoyance kernel: usb 1-3: WARN: invalid context state for evaluate context command.
Sep 29 21:15:31 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:31 annoyance kernel: xhci_hcd 0000:2a:00.1: ERROR: unexpected setup context command completion code 0x11.
Sep 29 21:15:31 annoyance kernel: usb 1-3: hub failed to enable device, error -22
Sep 29 21:15:31 annoyance kernel: usb 1-3: WARN: invalid context state for evaluate context command.
Sep 29 21:15:31 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:31 annoyance kernel: xhci_hcd 0000:2a:00.1: ERROR: unexpected setup address command completion code 0x11.
Sep 29 21:15:32 annoyance kernel: xhci_hcd 0000:2a:00.1: ERROR: unexpected setup address command completion code 0x11.
Sep 29 21:15:32 annoyance kernel: usb 1-3: device not accepting address 52, error -22
Sep 29 21:15:32 annoyance kernel: usb 1-3: WARN: invalid context state for evaluate context command.
Sep 29 21:15:32 annoyance kernel: usb 1-3: reset full-speed USB device number 52 using xhci_hcd
Sep 29 21:15:32 annoyance kernel: xhci_hcd 0000:2a:00.1: ERROR: unexpected setup address command completion code 0x11.
Sep 29 21:15:32 annoyance kernel: xhci_hcd 0000:2a:00.1: ERROR: unexpected setup address command completion code 0x11.
Sep 29 21:15:32 annoyance kernel: usb 1-3: device not accepting address 52, error -22
Sep 29 21:15:32 annoyance kernel: usb 1-3: USB disconnect, device number 52
@foostan
Copy link
Owner

foostan commented Oct 13, 2024

Thank you for the information. I have received some reports, but I have not yet been able to identify what the cause is. I will review some of the design policies and try to improve them.

@xkonni
Copy link
Author

xkonni commented Oct 13, 2024

if you need any further information or have an idea how to fix existing pcbs I'm all ears!

@l4u
Copy link

l4u commented Oct 14, 2024

@xkonni can you let us know the distro and kernel versions please?

@xkonni
Copy link
Author

xkonni commented Oct 14, 2024

sure, here are my 3 test computers

  • Dell Latitude 7420, ubuntu 22.04 with 6.8.0-45-generic
  • Dell XPS 7390, arch with 6.11.3-arch1-1
  • PC, arch with 6.11.3-arch1-1

@foostan
Copy link
Owner

foostan commented Oct 14, 2024

Is yours cherry or chocolate?
How about the communication between the left and right sides. Is the USB connection unstable only?

@xkonni
Copy link
Author

xkonni commented Oct 14, 2024

I got two 4.1 here, one cherry, one choc. they behave exactly the same. On a usual day they work. Does not matter which one I use.

Then after a while the usb issues appear. Changing usb from left to right does not help, switching cherry to choc does not help.
My left side is normally plugged in via usb, right via trrs. Sometimes the left side still works, right does not. But then replugging the left or switching to the right just leads to more usb errors in the kernel log.

A cold boot sometimes helps.

@foostan
Copy link
Owner

foostan commented Oct 14, 2024

Thank you for sharing the details!

@foostan foostan added the fix/pcb Fix request for PCB label Oct 19, 2024
@github-project-automation github-project-automation bot moved this to Backlog in KBD Roadmap Oct 19, 2024
@foostan foostan moved this from Backlog to Researching in KBD Roadmap Oct 19, 2024
@PaulRopel
Copy link

I’m also experiencing some disconnect issues with my Core v4.1. When I plug it in and use it to practice on keybr.com, it works well. However, if I set it aside (while it’s still plugged in), switch to browsing, or use my Mac keyboard, the Core v4.1 stops responding when I try to use it again, even though the LED remains on. Tell me if I can help somehow troubleshooting...

@dahmwern
Copy link

dahmwern commented Nov 1, 2024

I'm having similar issues as well. Seems to be that the non-plugged side disconnects most often, but sometimes I'll get disconnects on the plugged in side as well. I saw the LEDs flicker when this happened, which isn't suprising, but it was a series of very short bursts of flickers which makes me think it's a Power-related issue.

@foostan
Copy link
Owner

foostan commented Nov 1, 2024

This is just a guess, but from some reports I've heard it seems to be a power supply issue. There are some parts that are not very well designed, and some of them may be defective.

I'd like to isolate some of the root causes, and I'd appreciate any information you could give me.

  • Does the problem happen on a different PC?
  • Does the problem happen on another Corne v4 (if you have one)?

@dahmwern
Copy link

dahmwern commented Nov 1, 2024

I'd like to isolate some of the root causes, and I'd appreciate any information you could give me.

* Does the problem happen on a different PC?

* Does the problem happen on another Corne v4 (if you have one)?

I've had the issue on a Mac. I do have a spare PC that I can test with later this weekend and report back.

No spare Corne v4.1 keyboards assembled to test with easily.

@dahmwern
Copy link

dahmwern commented Nov 1, 2024

Update:

Set up:

  1. Connected via USB C to MacBook Pro directly and with USB C hub
  2. USB C to right half of keyboard
  3. TRS between halves

I used the Corne V4.1 all day today, about 10 hours of use during work. I experienced a total of about 10 losses of function, some back to back, with varying amount of time between them.

Left hand (slave side) had about 6-7 losses of function. Right hand (master side) had about 3-4 losses of function. On one occasion, losses of function occurred every 30 seconds and required the keyboard to be reflashed.

Each time there was loss of function, it was preceded by LED flickering.

Hope this helps! I'm happy to set up more Corne V4.1s to test in varying conditions.

@dahmwern
Copy link

dahmwern commented Nov 6, 2024

Another update:

I swapped my keyboard out with another Corne v4.1 PCB this evening. I did this to verify that there were no hardware issues with the first PCB. I also used the same firmware to avoid SW variation.

I confirmed the same behavior with keyboard lockup on one side resulting in requiring a power cycle to recover.

This is a big issue! Right now I can't use my (5) Corne v4.1's nor can I use a v4.1 as my daily driver with these reliability issues.

@foostan have you looked into this any further?

@foostan
Copy link
Owner

foostan commented Nov 6, 2024

Thank you for your confirmation. Unfortunately, this problem does not occur in my environment, so I cannot investigate further.

@alessiocurri
Copy link

alessiocurri commented Nov 6, 2024

Hi,
i can report i have the same issue.
The keyboard locks up so much it's impossible to use. I tested the keyboard with two different set of pcbs (both chocolate), with multiple computers (mostly linux, a windows out of desperation).
I also tried flashing a custom KMKFw one-side-only setup and, later, a custom QMK firmware. Multiple USB cables, HUBs, no Hubs, Hid-remapper in front of the keyboard. Same result.
The two pcbs were sourced from different vendors in Europe, i tested both.

How can we help you further investigate this issue?

edit:
i forgot to add, the keyboards seems to lock a less with QMK.

@chadhakala
Copy link

FYI the second USB port will work (opposite hand) however your special keybinds may behave differently from your custom layout; found this to be a pleasant surprise considering a USB port joint was damaged on mine and the opposite ha d allows me to work around the one broken USB jack.
Not sure of this will solve your problem but worth a shot and worth knowing it appears to be different from older branches in that way.

@foostan
Copy link
Owner

foostan commented Nov 6, 2024

Another possibility is that the PCB is simply damaged. Please also contact your supplier for further information.

@alessiocurri
Copy link

@foostan 4 different PBCs from 2 different vendors show the exact same exact issue, both used as a pair and as a single unit (with a custom firmware).
The same issue reported by other user in the this thread.
I assembled the keyboard myself, and inspected the second set of PCB i got very carefully when i received them: the only reason I bought a second set was to test if my unit was the issue.
The custom software was tested on an generic RP2040, to test the stability: no issues for days while the same (KMKfw) software running on the corne has usb issues after a few minutes. I can reproduce this with all my 4 units (2 left and 2 right ones) and it works fine on any other RP2040 i tested.

I had spent quite a lot of time trying to debug and i'm 100% positive it's not a single unit, it's not my computer, the usb cable or simila.

What i'm hoping to get here is some help in further debugging what is an issue with the USB on the keyboard, and hopefully find a solution/workaround to help the other user that may have the same issue.

So, in that light, is there any other info i can provide?

@chadhakala no, the usb port is not damaged at all.

@foostan
Copy link
Owner

foostan commented Nov 7, 2024

Thank you for sharing the details. I'm glad you're being helpful.

So what you're reporting means is that the issue is more likely to occur with KMKfw than with QMK? I'll give KMKfw a try. Thanks again.

@dahmwern
Copy link

dahmwern commented Nov 7, 2024

@foostan I don't think he's saying the KMKfw is worse, but rather by testing the same firmware on a generic RP2040 and on the Corne v4.1 board, the issue is only present on the Corne v4.1. This eliminates as many noise factors as conveniently possible.

The help needed is some debugging on the Corne v4.1 USB HW design to understand what's unique to the design that's causing the issue.

Please let us know if you need data. I am fully willing to support as needed. I would love to help solve this.

@foostan
Copy link
Owner

foostan commented Nov 7, 2024

I'm sorry, of course. I didn't mean KMKfw is worse. I would like to isolate the problem and investigate the cause in detail.

Thank you for your cooperation. Let's share information on this issue.

@ChadHacksaLot
Copy link

@foostan 4 different PBCs from 2 different vendors show the exact same exact issue, both used as a pair and as a single unit (with a custom firmware). The same issue reported by other user in the this thread. I assembled the keyboard myself, and inspected the second set of PCB i got very carefully when i received them: the only reason I bought a second set was to test if my unit was the issue. The custom software was tested on an generic RP2040, to test the stability: no issues for days while the same (KMKfw) software running on the corne has usb issues after a few minutes. I can reproduce this with all my 4 units (2 left and 2 right ones) and it works fine on any other RP2040 i tested.

I had spent quite a lot of time trying to debug and i'm 100% positive it's not a single unit, it's not my computer, the usb cable or simila.

What i'm hoping to get here is some help in further debugging what is an issue with the USB on the keyboard, and hopefully find a solution/workaround to help the other user that may have the same issue.

So, in that light, is there any other info i can provide?

@chadhakala no, the usb port is not damaged at all.

@alessiocurri My apologies--I didn't realize this thread was all about the lockup; while,I have faced this issue and other unique issues for which I do not have systematic evidence for being a USB fault.

The last time I used the corne I did face this exact lock up issue and stop using it completely for that reason, I am following all these threads so my apologies, little embarassed for chiming in didn't even read the full thread; I'm pretty sure I meant to respond to a different comment in the thread and was unaware there was even an issue for lockup.

@alessiocurri
Copy link

@dahmwern exactly what i meant ;)

@foostan here https://gist.github.com/alessiocurri/18e6b0c48a74c37dee766a71a22ac62a you can find my config for a left-only corne 4.1, no TRRS cable nor right side necessary.
This script will run fine on any circuitpython, i tried on versions 8.x, 9.1 and 9.2 (no changes).

To install kfmfw I just copied the kmkfw files from the github repo, added the neopixel.py library (you can also use the .pyc, it should be the same) and my code.py and boot.py (the latter is not strictly necessary). Please note the default layer is empty. To test you need to switch to another layer, the leds will highlight the active keys.

In this config i can replicate the usb lockup on average in 20 minutes, using all 4 boards (tested without the switches, with, no difference). The easier way to check the status is to use a serial console con the virtual com port exposed. There you can find the python REPL. That virtual serial port will disappear when the usb issue presents itself.

@ChadHacksaLot no prob at all, probably it's me owning an apology... in my reply i have been very blunt, probably a tad much :)

@viscount-monty
Copy link

Just wanted to add that I'm experience what sounds like the exact same issue with my corne v4.1.

Same behaviour everyone above is describing - sometimes one side becomes unresponsive, sometimes both, sometimes it works nearly all day, sometimes it's only seconds or minutes until the next lockup after disconnecting and reconnecting the USB cable.

One time, the right side even changed colour to the pattern pictured below:
image

Same behaviour when plugged into

  • Desktop PC running Windows 10

  • The same PC running Linux Mint 22 Cinnamon

  • Pixel 6 phone (Android 14)

  • lsusb during failure, both sides, Linux Mint

    Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
    Bus 001 Device 003: ID 0665:5161 Cypress Semiconductor USB to Serial
    Bus 001 Device 004: ID 3434:d030 Keychron  Keychron Link 
    Bus 001 Device 005: ID 0b05:18a3 ASUSTek Computer, Inc. AURA MOTHERBOARD
    Bus 001 Device 006: ID 8087:0aaa Intel Corp. Bluetooth 9460/9560 Jefferson Peak (JfP)
    Bus 001 Device 011: ID 1532:008f Razer USA, Ltd Razer Naga Pro
    Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub
    
  • lsusb after disconnect/reconnect

    Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
    Bus 001 Device 003: ID 0665:5161 Cypress Semiconductor USB to Serial
    Bus 001 Device 004: ID 3434:d030 Keychron  Keychron Link 
    Bus 001 Device 005: ID 0b05:18a3 ASUSTek Computer, Inc. AURA MOTHERBOARD
    Bus 001 Device 006: ID 8087:0aaa Intel Corp. Bluetooth 9460/9560 Jefferson Peak (JfP)
    Bus 001 Device 011: ID 1532:008f Razer USA, Ltd Razer Naga Pro
    Bus 001 Device 023: ID 4653:0004 foostan Corne v4
    Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub
    
    

I absolutely adore this keyboard when it works, I would love to assist in some way. I have career experience in PCB design and experience in micro-controller firmware programming - let me know what I can do to help or point me in a direction please :)

@dahmwern
Copy link

dahmwern commented Nov 8, 2024

@viscount-monty I've experienced that same LED pattern during lockup. Your description is consistent with my experience.

What information do you need to analyze the PCB design for potential USB related comms issues?

@foostan
Copy link
Owner

foostan commented Nov 9, 2024

It seems that it may or may not occur depending on the environment. I don't know under what conditions it occurs, but has anyone noticed any electrical abnormalities when the problem occurs, such as a short interruption or a significant drop in voltage or current?

@foostan
Copy link
Owner

foostan commented Nov 23, 2024

I'm changing the position of RP2040 to the center of PCB.
image

@viscount-monty
Copy link

@foostan may I ask why you didn't go for a ground plane pour on both sides of the corne?

The image you posted of the Cornelius appears to show a ground plane pour on the micro-controller side, though it seems to lack any 'stitching' vias. If there is no ground plane pour on the other layer that would make sense though.

I'm not certain it would make a difference, but I'm used to seeing/designing RF boards with top and bottom ground plane pours, stitched with vias at reasonable intervals.

Example:
image

@foostan
Copy link
Owner

foostan commented Nov 25, 2024

@viscount-monty Can you tell me what its significance is? I didn't do it because I didn't know what effect it would have.

@fabianmuehlberger
Copy link

@foostan may I ask why you didn't go for a ground plane pour on both sides of the corne?

The image you posted of the Cornelius appears to show a ground plane pour on the micro-controller side, though it seems to lack any 'stitching' vias. If there is no ground plane pour on the other layer that would make sense though.

Instead of a pour on top an bottom, I highly recommend making a 4 layer board.

The top layer is segmented due to the lines, having a solid inner ground would be beneficial.

  1. Easier routing
  2. Clear current return paths
  3. The high speed lines can be via fenced for isolation.

@foostan
Copy link
Owner

foostan commented Nov 25, 2024

I have already verified the four-layer design and prototype. Although the wiring has certainly been simplified, I have concluded that the benefits were not enough to justify the increased costs.

@viscount-monty
Copy link

@foostan Certainly - proper grounding/shielding prevents EMI, either emitting RF which could interfere with other devices, or shielding the device from other source of RF interference. Similar to how a co-axial cable features a shield/ground which entirely covers the signal conductor. This kind of grounding/shielding is required to make RF PCBs function correctly and pass compliance testing.

To think of it another way, a PCB trace could accidentally behave as an antenna for external interference if not shielded/grounded sufficiently.

@foostan
Copy link
Owner

foostan commented Nov 28, 2024

So, let's put a ground around the edge of the board as much as possible. That alone will have an effect. As mentioned above, I will not use a 4-layer board.

@foostan
Copy link
Owner

foostan commented Nov 28, 2024

The latest board is here. I'll confirm again and create a prototype.

  • Move a MCU to the center of a board
  • Important signal lines should be as thick and short as possible, and the number of vias is reduced as much as possible.
  • Put GND for EMI and EMS.

image
image

@viscount-monty
Copy link

Nice work, looks great! I'm looking forward to hearing how the prototype turns out 🤞

@dahmwern
Copy link

Can't wait to hear the results. If you need other people to help you test your boards... Just saying :)

@fabianmuehlberger
Copy link

fabianmuehlberger commented Nov 30, 2024

The latest board is here. I'll confirm again and create a prototype.

* Move a MCU to the center of a board

* Important signal lines should be as thick and short as possible, and the number of vias is reduced as much as possible.

* Put GND for EMI and EMS.

Not quite. The USB lines should not be "as thick as possible" but rather have the correct impedance.

Regarding trance length: For a high speed USB signal, a conservative approach for a 2 layer board (according to the article) would be to stay under the 25% limit, which is roughly 20 mm line length.

Beside good shielding from EMI this is also an important factor for signal integrity. Below is a guide for 2 layer boards.
https://resources.altium.com/p/routing-requirements-usb-20-2-layer-pcb
Impedance calculator: https://www.pcbway.com/pcb_prototype/impedance_calculator.html

@foostan
Copy link
Owner

foostan commented Nov 30, 2024

Thanks for the detailed information and feedback. I will try to calculate the impedance and improve it.

@fabianmuehlberger
Copy link

fabianmuehlberger commented Dec 1, 2024

To make it clear: The impedance is not the only criteria for USB. Implementation according to best practices and hardware design guides as mentioned in other posts are critical if you want your product to be within the specification.

This is a general overview of the EMC USB specification https://www.we-online.com/components/media/o109031v410%20ANP024d_The%20USB%20Interface%20from%20EMC%20Point%20of%20View.pdf

If you plan to sell your product in the EU, you have to comply with the regulations described here https://single-market-economy.ec.europa.eu/sectors/electrical-and-electronic-engineering-industries-eei/electromagnetic-compatibility-emc-directive_en
For other markets, similar regulations apply.

@b3n-l
Copy link

b3n-l commented Dec 6, 2024

Just as an external comment, I've got an RP2040 based split board that exhibits similar behaviour when a mobile phone is placed near the board. (Fingerpunch ximi v2).

I managed to reduce the symptoms significantly by using a shielded USB-C cable

@PaulRopel
Copy link

The latest board is here. I'll confirm again and create a prototype.

* Move a MCU to the center of a board

* Important signal lines should be as thick and short as possible, and the number of vias is reduced as much as possible.

* Put GND for EMI and EMS.

image image

hi, not pushing just like to know how long does it take to make the prototype?

@foostan
Copy link
Owner

foostan commented Dec 11, 2024

I ordered it last week.

@bridgerbrown
Copy link

Another temporary fix seems to be using a powered USB hub with EMI shielding. I've been using my Corne v4.1 for a couple weeks now through one without this issue, then today started plugging it directly into my laptop via usb C and the issue started. I'm gonna try a more shielded usb C cable for travel now.

My details are the same as others have already stated: left split is plugged in via usb, right split connected to left via trrs. Phone gets close, the right split will stop taking input after a short period (but keeps rgb on with animation paused), and left still works. Have to unplug and replug for it to start working again, and then it will last anywhere from 5-30s depending on how close the phone is I guess. Issue goes away with enough distance.

@saitharun14
Copy link

Hello,

First, I'd like to thank you for your fantastic work on the crkbd. Please keep it up!

I'm writing to see how things are progressing with the current issue. I'm very excited about the crkbd v4 and am waiting for this to be resolved before building the keyboard. Thanks again for all your hard work!

@foostan
Copy link
Owner

foostan commented Jan 7, 2025

I'll share the current status

  • I created the new version (v4.1.1) of Corne Cherry and ordered it in December. The problem has been resolved, and I have confirmed that it works as intended. However, I made another mistake, so I am currently fixing it.
  • I have also been working on Corne Chocolate in order to release it at the same time.
  • The design for both Cherry and Chocolate is almost complete, so I will be placing orders soon. If I find no problems, I will release it.

@johnynfulleffect
Copy link

johnynfulleffect commented Jan 16, 2025

Came here to report the same issues as everyone else with v4.1 and happy to hear that this is being resolved with a new board design. Please post when this goes on sale!

Would some EMI shielding tape in the case help with our current boards? If so, approximately where would we tape? The entire case surrounding the PCB or just cover a particular chip on the PCB?

Thoughts on this? https://www.3m.com/3M/en_US/p/d/b00041293/

Thanks for all your work here!

@viscount-monty
Copy link

Came here to report the same issues as everyone else with v4.1 and happy to hear that this is being resolved with a new board design. Please post when this goes on sale!

Would some EMI shielding tape in the case help with our current boards? If so, approximately where would we tape? The entire case surrounding the PCB or just cover a particular chip on the PCB?

Thoughts on this? https://www.3m.com/3M/en_US/p/d/b00041293/

Thanks for all your work here!

You're correct in thinking shielding can help, but due to the nature of the corne case (doesn't cover the top of the PCB), what you're suggesting may potentially make the noise issues worse.

Shielding (creating a Faraday cage around the item to be shielded) works if the conductive material entirely surrounds the item, or, to a lesser extent, if the shielding material is between the item and the source of the noise (in this case, that would mean shielding over the top of the keys).

If you were to place shielding material in the case, this would mean you essentially have the following configuration:

----noise source----

====PCB=============
----shield----------

Which is essentially a 'patch antenna', meaning it could possibly amplify the noise level experienced by the PCB. To oversimplify a little, picture the RF noise reflecting off the shielding after passing through the PCB, only to pass back through the PCB again.

@humanplayer2
Copy link

What if one uses tin foil as a "PE foam mod" on top of the PCB, under the plate (with large enough holes to not touch the pins)?

@viscount-monty
Copy link

viscount-monty commented Jan 17, 2025 via email

@yanos626
Copy link

yanos626 commented Jan 17, 2025

^am interested too to know if that works.

If anyone here has confirmed a free/cheap diy fix to work around v4.1's issue, that would be great so i can keep using the corne i already have instead of having to buy a whole new 4.1.1 board. - though much appreciated this was addressed in 4.1.1 moving forward 💯

Seems using a "shielded" usb cable works for 4.1? Where could i find this in amazon

@johnynfulleffect
Copy link

I found some EMI shielding tape, that is non-conductive. But would like to know really what I should be shielding from @foostan . The entire PCB? A section of it? A certain chip?

@johnynfulleffect
Copy link

So to update on my issue, turing on Airplane mode on my iPhone 16 Pro Max and allowing Wifi, prevents this issue completely. So it is cellular signal that interferes with the Corne. I also noticed some interference on my speakers and headphones when cell service was on. That interference is gone on Airplane mode and the Corne works perfectly.

@viscount-monty
Copy link

  • Did you mean insulated shielding tape? Or shielding tape with non-conductive adhesive? For anything to act as an RF shield, it must be conductive.
  • Considering @foostan had the same issue on their aluminium bodied Cornelius keyboard (PCB within aluminium case), more shielding may not be the solution, especially if it isn't electrically connected to the GND of the PCB, though I may have misread that comment.
  • Having said that, it can't hurt to try. Areas of interest would be the RP2040 chips and the PCB traces between them and the USB ports.

@johnynfulleffect
Copy link

Thanks @viscount-monty I am new to this. Will try things and report back.

@johnynfulleffect
Copy link

Introducing the “Faraday Mod” for the Corne v4.1

Pics: https://imgur.com/a/Xzk7oNd

It seems to have worked!

Copper EMI shielding conductive tap: https://a.co/d/16tvJXh

@foostan
Copy link
Owner

foostan commented Jan 26, 2025

Considering @foostan had the same issue on their aluminium bodied Cornelius keyboard (PCB within aluminium case), more shielding may not be the solution, especially if it isn't electrically connected to the GND of the PCB, though I may have misread that comment.

When I tested it with Cornelius, I used only the PCB and placed the IC and phone as close as possible. I have never had any problems with everyday use.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
fix/pcb Fix request for PCB
Projects
Status: Researching
Development

No branches or pull requests