ggm 16 hours ago

this is classic computing wheel of life stuff (Bell, Mudge, MacNamara wrote that up in the 70s)

* first you do it in the cpu * then you do it in a dedicated card off the bus * then you find the FPGA or whatever too slow, so you make the card have it's own CPU * then you wind up recursing over the problem, implementing some logic in a special area of the cpu, to optimise its bus to the other bus to ...

I expect to come back in 10years and find there is a chiplet which took the rpi core, and implements a shrunk version which can be reprogrammed, into the chiplet on the offload card, so we can program terabit network drivers with a general purpose CPU model.

  • TZubiri 9 hours ago

    I understood some of these words

    • Twirrim 2 hours ago

      We start out doing things in the CPU, create dedicated hardware for it externally, then slowly but surely bring it closer and closer to the CPU until we end up integrating the specialist capabilities into it. Often these capabilities enable other workloads to be done in the CPU, that we then build dedicated hardware for and the cycle continues.

      An easy example is the 8087 maths coprocessor, from the early 80s. They were floating point accelerators, a separate chip you could plug into your motherboard, until eventually it was integrated into the CPU (386 and 486 processors had SX and DX variants, DX had the coprocessor integrated)

ChuckMcM 18 hours ago

Fun stuff. You kids don't know how lucky you are to have really capable MCU's for just a few bucks. :-)

It is kind of the ultimate "not a TOE[1]" example yet.

[1] TOE or TCP Offload Engine was a dedicated peripheral card that implements both the layer 1 (MAC), layer 2 (Ethernet), and layer 3 (IP) functions as a co-processing element to relieve the 'main' CPU the burden of doing all that.

  • kace91 3 hours ago

    >Fun stuff. You kids don't know how lucky you are to have really capable MCU's for just a few bucks. :-)

    Any suggestions for people not used to tinkering with hardware? I would like to play I think, but I have a lack of imagination regarding potential projects/goals.

    • bux93 2 hours ago

      I have plenty of ideas, I'm just super lazy!

      I'd like to hook up a rain sensor to a skylight to close it when it rains (needs a little motor, too), and then also hook it up to weather forecasts.

      I currently have to switch on my TV, surround set and a laptop, and then push multiple buttons to switch to/from a firestick. I'd like to automate that, so I can just switch it on/off and switch the source easily. Also if the system is in an unknown state (tv on, but using the incorrect HDMI input and the surround set if switched off, etc.), which is what the naive solution using a "fingerbot" and a IR blaster hooked up to godawful tuya stuff doesn't do.

      Build a GPS-synchronized flip clock.

      Add remote control door opening without destroying my flat's intercom system.

      Mostly kinda boring home automation stuff, but would be worth it for tinkering.

  • kragen 11 hours ago

    Or just a few cents! Possibly that will only last until war in Taiwan, though, or until it becomes impossible to find anything but counterfeits.

  • hunta2097 7 hours ago

    I can't get my head around it sometimes. I know most end up doing duties that a PIC-chip could do but the fact you can get a WiFi enabled microcontroller few a few bucks blows my mind.

    The IO co-processing on the Pico is so powerful, I hope they expand on this.

    • HeyLaughingBoy 25 minutes ago

      Right? Especially when I remember paying $20 each for an 8-bit microcontroller with less than 1k EPROM.

    • nerdsniper 3 hours ago

      It's also not really clear that using some of the more powerful chips for simple things is really a "waste" in any reasonable sense of the word. The packaging of a PIC/CH32 is probably the majority of its cost and environmental "footprint".

      An RP2040 is not much more physical material.

      An ESP8266/ESP32 is rather bit more material, but still not egregious.

  • nine_k 15 hours ago

    Don't modern NICs do a lot of the same, too?

    • tyingq 13 hours ago

      Sometimes it goes the other direction. PCI SSL accelerator cards were a thing for a long time before CPUs got faster, got various crypto acceleration opcodes, web servers rewrote SSL logic in ASM, etc.

      • carlhjerpe 3 hours ago

        The fancy Mellanox NVIDIA Connect-X cards have kTLS support which offloads encryption to the NIC, Netflix has blogged about how they use it to send 100 Gbps encrypted traffic of a single box (Their OpenConnect infrastructure is really cool).

        Old is new again :)

eqvinox 12 hours ago

This is only talking about TX, presumably it can't receive? That'd be the hard part...

  • matthiasl 8 hours ago

    Right, it's TX-only. The article says so explicitly halfway through:

    "As before, this is a transmit-only proof of concept"

    I didn't notice that on my first reading.

    • moffkalast 8 hours ago

      And here I was thinking I could use a Pico as a USB ethernet dongle in a pinch /s

junga 4 hours ago

> Raspberry Pi Pico Bit-Bangs 100 Mbit/S Ethernet

Per Siemens? I'd prefer Ohm!

sherinjosephroy 7 hours ago

Pretty wild that they got 100 Mbps Ethernet working on a Pico. Total overkill, but that’s what makes it fun — pure hacker energy.

  • inferiorhuman 7 hours ago

    Not quite the same but I was looking at PowerBook G4 specs last night. Apple was doing gigabit ethernet in a mid-priced laptop ($2200 in 2001 dollars) 25 years ago. Meanwhile I'm pretty sure I have some 10baseT gear kicking around.

    • dd_xplore 6 hours ago

      It’s not the same thing! Pico is a microcontroller, it’s also not a native ethernet implementation.

    • MBCook 3 hours ago

      That would have had a dedicated chip doing the work.

majke 5 hours ago

I'm confused. Why is there gnuradio on the screen? The RPI seems to have power (micro usb), TX (two wires to the ethernet port on the laptop), and ... what is the third thing?

  • tecleandor 4 hours ago

    I think it's the signal they're "converting" to ethernet. That'd be the "digitizing some WBFM IF signal with the internal ADC" part. What I don't know is what's in the signal :P

rasz 12 hours ago

Great hack from very talented hacker. Steve Markgraf is the author of High Speed Data Acquisition over HDMI https://github.com/steve-m/hsdaoh Capturing raw data using super cheap USB3 HDMI Video Capture dongles. Up to 175MB/s with Pico2 as the sender https://github.com/steve-m/hsdaoh-rp2350

Sadly 100Mbit might be the limit for bitbanging ethernet. While 1Gbit uses easily reachable 125MHz clock it also does full duplex requiring echo cancellation and I dont see an easy way around external PHY. The next PICO challenge is implementing GRMII PHY support for that sweet $1 RTL8211 1Gbit. I havent seen that done yet.

  • kragen 11 hours ago

    Hey, this is fantastic! Thanks!

unixfg 18 hours ago

Would this have been possible without PIO?

  • codebje 16 hours ago

    On a Pico? No - the PIOs replace other peripherals a µC might be able to use to achieve this sort of bitrate, so you'd not really have the tools you'd need to change GPIO pin states once every 3-4 CPU clock cycles.

    In a sense the PIO is a bit 'cheaty' when claiming "bit-banging", because the PIO is the ultimate peripheral, programmable to be whatever you need. It's no mean feat to make the PIO do the sorts of things happening here, by any stretch, but "bit-banging" typically means using the CPU to work around the lack of a particular peripheral.

    From that perspective, there's precious few µCs out there that could bit-bang 100MBit/s Ethernet - I'm no expert, but I _think_ that's a 125MHz IO clock, so if you want 4 CPU cycles per transition to load data and push it onto pins, you're looking for a 500MHz µC, and at those speeds you definitely have to worry about the bus characteristics, stalls, caching, and all those fun bits; it's not your old 8-bit CPU bit-banging a slow serial protocol over the parallel port any more.

    • kfterrg67 16 hours ago

      >"bit-banging" typically means using the CPU

      This is significant. It's using a hardware peripheral that is designed and intended for high frequency IO manipulation without CPU intervention. This isn't bit-banging, lest we start calling it "bit-banging" any time an FPGA or ASIC or even a microcontroller peripheral handles any kind of signalling.

      • ssl-3 14 hours ago

        It's a programmable hardware peripheral runs compiled software to toggle pins in a way that is entirely defined by that software.

        Here, it runs software that allows it to talk 100mbps Ethernet.

        Someone else might use that same hardware peripheral to drive a display, or produce a PWM output, or whatever.

        The RP PIOs just run software. That software can bang bits.

        • Dylan16807 13 hours ago

          Technically it's running software on the programmable I/O, but that software is just a loop of four outputs that advances when it gets a 1 bit and doesn't advance when it gets a 0 bit. It feels like the hardware that manages the buffer and turns it into a high speed serial stream is doing the more important work here.

          And the CPU that's actually deciding on the bits doesn't have to bang them with precise timing, it just has to put them into that buffer.

        • picture 14 hours ago

          Yeah but like FPGA fabric can also be programmed (sometimes by actual software like on Zynq or Stratix SoCs), would you call those bit banging too?

          • KeplerBoy 9 hours ago

            I feel most people would unless you use some Hard IP for the interface. Like you don't bit-bang PCIe when you feed a wide AXI stream at a few MHz into the PCIe block where it get's serialized and put onto the lanes at the signalling rate (multiple Gigahertz, depending on generation).

          • ssl-3 13 hours ago

            I don't have any hands-on experience with FPGAs. I only know about as much about FPGAs as I do about red herring.

    • rasz 12 hours ago

      >On a Pico? No

      but Yes on pico2 because RP2350 has separate fast serializer (HSTX) hardware block able to clock out at 2x the global clock (DDR). 320MHz OC results in 600Mbit output. Here example pumping out 175 MByte/s of data encoded as HDMI signal (3 lanes) without touching PIOs https://github.com/steve-m/hsdaoh-rp2350 to be used with $6 MS2130 USB 3.0 4k HDMI Video Capture dongle.

      • codebje 12 hours ago

        They really are pretty awesome little ICs. Thanks for the interesting link!

    • Neywiny 15 hours ago

      Ehhhhh the picture shows a very short cable. You can most certainly find micros that can run 100Mb/s communication interfaces, though sure maybe not bitbanged. However, you really need a PHY and magnetics. MII is 25MHz which seems fine. GMII is 125 MHz SDR which is something. Honestly that would've been a cooler demo IMO than running 2 inches

    • bitwize 10 hours ago

      It's why I call the Pico a "headless Amiga"—the PIOs are basically Coppers but for general I/O instead of tied to a display.

      I just wish the toolchain weren't so janky...

  • tylerflick 17 hours ago

    Not at that transfer rate. SPI which is the next fastest (common) protocol you find on micros typically operates around 10 Mhz, but this isn’t an apples to apples comparison.

varispeed an hour ago

I wish something like Pi Pico existed but with 1GHz clock, DDR3 memory interface and PCIe and few dozens of GPIO.

  • thijson an hour ago

    Xilinx Zync have PL for FPGA programmable logic, and PS with a few different ARM cores. They aren't as cheap as a Pi Pico though.

userbinator 14 hours ago

and must not be connected to PoE-enabled hardware.

I assume passive PoE; or does it also happen to look like a real PoE PD and trick the PSE into turning on?

  • moffkalast 8 hours ago

    Pico's reaction as it sees 48V signals on its 3.3V pins: perfectly cut scream that transitions into an explosion

amelius 8 hours ago

But how much juice is left to do useful stuff?

Dwedit 14 hours ago

People have bit-banged out analog NTSC and PAL video signals before.

  • karlgkk 14 hours ago

    I mean, that’s basically what a DAC is, half the time

    • Dwedit 12 hours ago

      Just usually not driven by timed code by a program running on a CPU. That's when it becomes bit banging.

brcmthrowaway 16 hours ago

How does PIO compare to Cypress PSoC?

  • deckar01 15 hours ago

    PIO is a set of coprocessors designed to offload signal processing. They have to be programmed. PSoC has FPGA like configuration capabilities, but rather than just logic gates it includes larger analog and digital ICs. You can route analog signal processing in and out without hitting a CPU and perform some FPGA like DSP driven by an arbitrary clock signal (also without any CPU usage).

    • brcmthrowaway 13 hours ago

      That sounds similar

      • deckar01 11 hours ago

        A coprocessor sounds similar to an FPGA?

  • sitzkrieg 2 hours ago

    stick with psoc for anything professional

karlkloss 11 hours ago

Or you could just buy an ESP32 board at about the same price, which already has an integrated Ethernet MAC (besides WiFi).

But where would be the fun in that?

  • rowanG077 10 hours ago

    You'd still need a Ethernet phy with the esp32 this does that too.

    • BertoldVdb 5 hours ago

      To make a compliant ethernet signal from this you would need at least some sort of line driver/receiver as well.

    • imtringued 3 hours ago

      That's the best part though.

      With an external PHY you can use single pair ethernet, which is much more suitable for use in embedded devices. Single pair ethernet directly competes against I2C and CAN, because you only need 2 wires for full duplex 100mbit/1000mbit connectivity.

      Single pair ethernet also has the massive advantage that it isn't restricted to the garbage RJ45 plugs, which are basically a nightmare in embedded devices.

hackingonempty 17 hours ago

PIO is great but the competition has working silicon and SDK for all of the common peripherals while RP gives you crappy example code. Want to connect to an audio codec with I2S? Almost every MCU has this built in but for RP2040/RP2350 you'll have to roll your own production quality version from a demo that only shows how to send. Years after release.