Running DeepSeek-R1 on refubrished blade server: 02 Power

Welcome back, Previous part here: Running DeepSeek-R1 on refubrished blade server: 01 Introduction.

Introduction/Plan

I am trying to build server for running DeepSeek-R1 on used supermicro blade, this part will cover my extermination with powering it on.

Reverse engineering server hardware and messing with power supplies can be risky. Please, be extremely careful in doing so. I am not responsible if something blows up.

Again let's start with basic plan:

Connecting

Let's start with dissecting original case:
Screenshot from backplane manual, shows simplified overview of it, minimal logic components (microprocessors) Link to case manual
Link to backplane manual

Looks like not whole a lot of components here, and very little logic. I decided to assume that Supermicro engineers are lazy (like I am) or they trust there is no dumbass (like me) who would try to power it directly from 12v. Simple short circuit check with multi-meter reveals: Side of connector that faces board is 12V, and the other one is GND.

Power requirements

Let's serach for original power supply. Little googling after, I found that it's 2x12v 2000w redundant PSUs.

This power supplies are for 4 nodes each (500w per node), but since they are Enterprise grade, there is non zero chance that they can push a little bit more over spec.

To be sure, I decided to get approx max power consumption just based on components:

Requirements:

Based on those I decided to choose: Mean Well LRS-600N2-12 It's:

Implementation, Type-0

Plan:

  1. Solder contacts directly to connector, as temporary solution (this is temporary solution while debugging, never solder power wires to flat pads.)
  2. Connect it to power supply
  3. Try to power it on, connect PSU with power meter in between to better understand what happens.

A close-up photo showing a modified backplane PCB with black and yellow wires soldered onto the edge connector pads. The wires end with red insulated fork terminals, indicating custom wiring for power connector. A top-view image displaying a blade server motherboard connected via a custom adapter to a standalone enclosed power supply unit (PSU). The setup shows connections and cables organized between the PSU terminals and the motherboard. A photograph of an electricity consumption meter plugged into an outlet. The meter’s display shows apparent power consumption of 19.9 VA, and a real power consumption reading of 4.0 Watts, indicating a very low power draw scenario. Aaaandd... nothing happens, PSU consumes 4W, fans doesn't start, IPMI1 Ethernet doesn't seem to connect.

I've also tried connecting to vga port; checked voltages on fanheader, USB, Sata power connector all of them show 0. That’s when I realized something critical was missing.

I guess Supermicro engineers aren't as lazy as I expected.

Reverse engineering backplane adapter

Two most important take from the chapter to the reader:

  1. RTFM, sometimes manufacturer will include pinout (In my case, I didn't found one)
  2. "reverse engineering if anything is more like playing Sudoku, your main goal isn't to find and answer, but try to reduce field of possibilities."

Basically there is several technics that best work in conjunction:

I decided that easiest way for me would be to try and make a copy of PCB and check voltages and continuities. Starting with making copy of PCB there is also three ways of doing it:

  1. Using high resolution X-ray (best and professional way, allows to do multilayered PCBs easily)
  2. Desolder every component, scanning on flatbed scanner.
  3. Take photo, and hope that it would be perfectly straight (most non destructive, and cheap)
    • Use zoom lens if you have one, it will reduce wrapping, I used Samsung DSLR from 2013 with 20-50mm lens, just because lens correction would be easier then on smartphone.
    • Use tripod
    • Use as much light as possible (be careful with flash as it can introduce unwanted glare, if you have ring one, it should work)
    • Close aperture as tight as possible, f/16-f/22 for maximum sharpness.
    • Don't try to take whole board as one photo, sticking one to another is much easier than not seeing traces at all.

Here short guide how to do 3rd option:

  1. Take photos
  2. Using darktable or any other software, apply lens correction (and hopefully your lens is in database)
  3. Export
  4. Use hugin to semi-automatically stitch your photos
    1. Use rectilinear projection (straight lines would be straight-ish, but check maybe something else would yield better results in your situation) BUT USE SAME PROJECTION FOR BOTH SIDES, otherwise it would be harder them to align in next steps.
    2. Map between images yourself, it's much easier (note: use barcodes, letters, etc. - this would give you ability to auto-finetune control points, I do not recommend vias, because they can look very different based on how light falls on them)
    3. When aligning, use user-defined assistant.
  5. Bring both of the sides into gimp/photoshop, mirroring one of the sides.
  6. Align them using handle tool.
  7. You should get something like this, and while images are stretched quite a bit vertically, it doesn't interfere with reverse engineering process too much. Syntetic image of front side of PCB, made by combining multiple photos of PCB Syntetic image of front side of PCB, made by combining multiple photos of PCB
  8. Import both to kicad and trace,trace,trace. (This step is one of the most time consuming in terms of labor).
  9. In kicad, set trace clearance to 0 mm, and track width to whatever will fit.
  10. In process also, try to guess what some of the chips are, the big rectangle ones were sata repeater chips, so anything that goes to or from them would be sata signals, and in my case not really interesting for reversing connector.
  11. I decided to start from motherboard connector to reduce need in tracing lines that are unused. Image of a printed circuit board (PCB) showing electronic components, pads, and with highlighted electrical traces. Two integrated circuits (ICs) are highlighted with red rectangles labeled as having unconnected pads, and traces are visibly routed from the PCB edge connector pads toward the IC to Motherboard connector.

Important things that I found:

RTFM

I started to debug by, again looking through limited documentation that I have, and found that PSU actually provides not only 12V, but also 2A 5VSB (Standby voltage), so, based on previos experemination I made educated guess that pins merged toghether and goes to two pins on the MB connector could be the ones that supply this 5V. Then, I traced it back to connector and hooked up DC-DC converter.

Drum rolls:

Let's try updating IPMI to the latest version to fix missing Web UI.

IPMI update can be sourced from manufacturer (SuperMicro) website, and in my case it came with software for procedure. (Win/Linux/Dos are usually supported)

Basically, to do procedure you need:

./2.08/linux/x64/AlUpdate -c -d backup.bin -i lan -h 192.168.2.42 623 -u ADMIN -p ADMIN
./2.08/linux/x64/AlUpdate -d fwdump.bin -i lan -h 192.168.2.42 623 -u ADMIN -p ADMIN 
./2.08/linux/x64/AlUpdate -f ./BMC_X10AST2400-C001MS_20211001_03.94_STD.bin -i lan -h 192.168.2.42 623 -u ADMIN -p ADMIN -r y

After 5 tries, update was done, and I was finally able to access web interface.

As for updating BIOS, for now it's not possible, because main CPU doesn't actually boot. I've tried powering it on through IPMI but it seems to be stuck in S5 state. Though, for the reference: To update SuperMicro BIOS through IPMI, you will need to activate it's license. Officially, you’re supposed to buy a license from Supermicro. Using a third-party key generator is definitely an unofficial route - and you take your own risks. But in the spirit of full disclosure, many people use it for homelab situations.

Continuing with pinout reverse engineering

Let's start with measuring voltages while server in S5 state. So, I made table to make this process more structured.

A-sideFunctionSystem state: S5/G2B-sideFunctionSystem state: S5/G2
1GND0V1Goes to U134, pin 3, power management IC1.64V
2SATA DIFF PAIR0V2GND0V
3SATA DIFF PAIR0V3SATA DIFF PAIR0V
4GND0V4SATA DIFF PAIR0V
5SATA DIFF PAIR0V5GND0V
6SATA DIFF PAIR0V6SATA DIFF PAIR0V
7GND0V7SATA DIFF PAIR0V
8SATA DIFF PAIR0V8GND0V
9SATA DIFF PAIR0V9SATA DIFF PAIR0V
10GND0V10SATA DIFF PAIR0V
11SATA DIFF PAIR0V11GND0V
12SATA DIFF PAIR0V12SATA DIFF PAIR0V
13GND0V13SATA DIFF PAIR0V
14SATA DIFF PAIR0V14GND0V
15SATA DIFF PAIR0V15SATA DIFF PAIR0V
16GND0V16SATA DIFF PAIR0V
17SATA DIFF PAIR0V17GND0V
18SATA DIFF PAIR0V18SATA DIFF PAIR0V
19GND0V19SATA DIFF PAIR0V
20U2 and U3, quadruple bus switch0V20GND0V
21U2 and U3, quadruple bus switch0V21U2 and U3, quadruple bus switch0V
22NCNC22U2 and U3, quadruple bus switch0V
23U2 and U3, quadruple bus switch0V23NCNC
24S20 (Eth LED)0.2V-4.8V (depends on state)24U2 and U3, quadruple bus switch0V
25S192.8V25S13.3V
26S18 (UID_LED)0.2V-4.8V (depends on state)26S24.8V
27S170V27R31(0.4 Ohm), then to S30V
28S163.1V28S40V
29S153.1V29R44, then to GROUND0V
30S144.82V30S63.3V
315V Rail5V31S73.2V
325V Rail5V32S80V
3312V Rail12V33GND RailGND
3412V Rail12V34GND RailGND
3512V Rail12V35GND RailGND
3612V Rail12V36GND RailGND
3712V Rail12V37GND RailGND

Then using kicad reference I traced each of pins to respective pins on motherboard:

S connBackplane pinFunctionVoltage in state: S5/G2
1B253.3V
2B264.8V
3R31 (0.4 Ohm), B270V
4B280V
5NCNCNC
6B303.3V
7B313.2V
8B320V
9NCNCNC
10NCNCNC
11NCNCNC
125V5V RAIL5V
135V5V RAIL5V
14A304.82V
15A293.1V
16A283.1V
17A270V
18A26UID_LED0.2V-4.8V (If uid is enabled in IPMI)
19A252.8V
20A24ETH_LED0.2-4.8V (If ethernet is connected)

Here is some possible guesses: S1 and S14 - stuck near 4.8V, so they could be some kind of LEDs (manual shows that there should be at least overheat LED), and there are 3.3V lines probably some kind of signals. To help progress debugging, I've decided to try checking up pins with logic analyzer. (Cheap Chinese 24 Mhz 8 channel logic analyzer work good for this task because I am not expecting to see any USB pins or something along the lines of it)

Then I just soldered wires directly to connector (there is testpads which I could have used to, but decided that it was easier/more secure to solder to connector directly)

Photo showing a PCB edge connector with soldered wires for power (yellow and black) and additional debug wires in multiple colors soldered directly to pads on the board. There is a small PCB module wrapped in clear protective tape, suggesting a temporary debug or monitoring setup. Yep, looks ugly, hot glue for strain relief of signal cables, small green pcb - dc-dc converter for 5V.

Overall, setup looks like this: A complete test setup on a wooden tabletop showing a blade server motherboard connected via custom wiring to a standalone power supply unit. Additional cables connect peripherals including a keyboard, external SSD, Ethernet cables, and a laptop (display blurred).

I started by hooking up logic analyzer to motherboard (A) side of connector, opening pulseview and turning PSU off/on we see: PulseView logic analyzer screenshot with digital signals across multiple channels (D0-D7). Channels D0-D4 exhibit clear signal transitions indicating active communication, while D5-D7 remain steady without activity.

ChannelConnector PinVoltage in S5/G2 state
CH0A270V
CH1A293.1V
CH2A283.1V
CH3A304.82V
CH4A252.8V

What was weird is CH3 not turning off, but this could be due to poor contact.

Then I hooked up logic analyzer to case (B) side of connector, again, opening pulseview and turning PSU off/on we see...

Wait, it turned on?

Ok, it seems that logic analyzer weekly pulls pin up or down and fans start spinning, weird. Then I remembered - ATX PSU usually have two pins in thier connection PS_ON and PWR_OK.

Let's look in pulseview:
Screenshot of PulseView logic analyzer software showing eight digital channels labeled D0-D7. The signals appear idle or steady-state, with no visible data transmission occurring.

ChannelConnector pinVoltage in S5/G2 state
CH0B280V
CH1B320V
CH2B303.3V
CH3B313.2V
CH4B270V

Observations:

Let's figure out what is PWR_OK, by simply disconnecting logic analyzer from pins on at a time. And on first try - CH0, it turns off. Weird, PWR_OK as to spec should be held high. Taking another wire and connecting pin B28 to 5V through resistor turns system on. Ok, it seems that there is some discrepancy between logic analyzer and spec, but if it works, it works.

Now, let's figure out, what is happening on CH2 and CH3. Screenshot of a logic analyzer capture (PulseView software) showing decoded I²C communication. It highlights the address 0x38 being sent in write mode, followed by a NACK (negative acknowledgment), with clearly visualized clock and data waveforms.

Zooming in and looking at it - looks preety much like I2C(SMBus) pair, enabling I2C decoder on the pins we see that it tries to access address 38 and getting NACK (Not acknoledged). So this is the way how motherboard usually communicates with PSU/backplane.

Now, going back to PWR_OK, CH0(B28 pin):

With CH0 pulled up to 5V though resistor, we get to boot. Checking IPMI Web UI we can see:
Screenshot of a Supermicro server boot screen displaying the message (No memory DIMM detected, install memory DIMMs) and (PEI--Intel Reference Code Execution...)

In next part, I am planning to go over designing and reciveing PCB, soldering all together, receiving ordered RAM and getting full OS boot.

Thanks for reading, When next part is available, link: insert link here.