Logic Level shifter for 12864 display on Duet 2 Wifi
-
I am trying to get the Mini 12864 working with my maestro, but it seems like I may have gotten the pinout wrong - the display lights up, but does not show anything... - is the final pinout somewhere documented?
I tried to follow the Maestro side identically to this post from Schmart i.e. Exp0 -> A0, Exp1 ->CS, remaining SPI pins from the EXP1 connector. For the display I followed the pinout from github. My config.g contains "M918 P2 E2". Issuing M112 yields "RepRapFirmware for Duet 2 Maestro version 3.2-beta2 running on Duet Maestro 1.0"
Did I miss anything?
-
@pixelpieper said in Logic Level shifter for 12864 display on Duet 2 Wifi:
, but does not show anything...
you have added menu files to the sd card?
is the final pinout somewhere documented?
best source will always be the source on github / Pins_DuetNG.h for the version in question
-
@bearer yes, I did. Just checked the maestro header file:
constexpr Pin LcdCSPin = PortCPin(9); constexpr Pin LcdA0Pin = PortAPin(21); // EXP_0 constexpr Pin LcdCSAltPin = PortAPin(22); // EXP_1
The chip select is defined twice, do I need to enable something else for the “alt” pin to work?
-
@pixelpieper said in Logic Level shifter for 12864 display on Duet 2 Wifi:
The chip select is defined twice,
once for lcd and once for sd card presumably?
-
@pixelpieper said in Logic Level shifter for 12864 display on Duet 2 Wifi:
@bearer yes, I did. Just checked the maestro header file:
constexpr Pin LcdCSPin = PortCPin(9); constexpr Pin LcdA0Pin = PortAPin(21); // EXP_0 constexpr Pin LcdCSAltPin = PortAPin(22); // EXP_1
The chip select is defined twice, do I need to enable something else for the “alt” pin to work?
Using an alternative pin for CS instead of the original CS pin is unfortunately necessary on a Duet 2 Maestro when using a ST7567. Here's some background. The electronics on the Maestro were originally designed with a ST7920-based display in mind. That display requires an active high CS. On the Maestro, the CS, clock (SCK) and data output (MOSI) signals are buffered by a 74HCT08 chip (from 3.3V to 5V) . Additionally, the SCK and MOSI are passed through (gated) only when CS is high. Now, the ST7567 display has an active low CS. Which means that if CS is low, SCK and MOSI will be blocked and useless. So therefore, the original CS is set high permanently, and the alternative pin EXP_1 (unbuffered 3.3V) is used for the active low CS to the ST7567.
The ST7567 also requires an additional pin to indicate if data sent to the display should be considered a command or display data. That is called the A0 and on the Maestro, EXP_0 is used for that.
Getting a ST7567 display to work successfully is based on the right wiring, configuration (display type, display contrast and resistor ratio), and a compatible display that accepts 3.3V levels, so there are quite some variables to get right. At least, the schema in my post that you mention is correct on the Maestro side, I'm using that right now.
-
@pixelpieper I've taken a look at the picture you provided, and as far as I can tell the wiring seems in order (based on the Fystec Wiki article).
-
@pixelpieper in the Wiki for this display I do see mentioned that dynamic contrast may not be supported. Did you play with the contrast parameter (e.g. try C100) already?
-
@Schmart Yes, I did, however there was no difference :(. Did pull out my scope for a change, there is traffic on A0 and CS as well as on MOSI/SCK. Will try to do a little bit more debugging later the week.
-
Well, it is alive. Turns out the display likes a nonactive reset to work - go figure.
Seems we can use the high active ST7920 chip select for this purpose.
-
@pixelpieper can this solution be applied to duetwifi?
-
@seraser this is not maestro specific - the lcd reset pin of the mini 12864 has to be somehow pulled high in order to have the display leave its reset.
@dc42 from the firmware side: when configured as M918 P2, are we guaranteed that the then not functional active high chip select on the maestro display connector stays always high? I.e. is it safe to use as the reset pin?
-
@pixelpieper said in Logic Level shifter for 12864 display on Duet 2 Wifi:
nonactive reset
Congratulations, great find! It's nice to see you also have the right tooling at hand to do the troubleshooting Apologies that I couldn't help you with this one, I don't have any Fysetc displays, and the Creality display I tested with doesn't need a reset.
As for your question to use the CS as RESET; does your display also work correctly when the reset pin is permanently tied to Vcc or does the reset signal need a delay?
-
@dc42 finally working duetwifi, after all pins connected without any modification.
Edit: enter key pushing encoder dont work![0_1602444104968_IMG_20201011_204711.jpg](Uploading 100%)
-
@pixelpieper said in Logic Level shifter for 12864 display on Duet 2 Wifi:
@seraser this is not maestro specific - the lcd reset pin of the mini 12864 has to be somehow pulled high in order to have the display leave its reset.
@dc42 from the firmware side: when configured as M918 P2, are we guaranteed that the then not functional active high chip select on the maestro display connector stays always high? I.e. is it safe to use as the reset pin?
Yes, it should be.
-
@Schmart now is working fine but no enter key detected when press encoder, what can I check?
Rotate work.
Thank you.
-
@seraser said in Logic Level shifter for 12864 display on Duet 2 Wifi:
no enter key detected
thats just a switch wired to EncoderPinSw so check the wiring and or voltage on the signal with the key pressed and not pressed?
-
@bearer will check this night, thank you.
-
@bearer thank you swaped beep with enc_sw and now LCD work fine but no sd card detected, checked and checked and checked wires and all are fine for sure and m122 only reports sdcard0.
-
Cs, miso, mosi and csk are fine connected and with 3v3 volts, tomorrow I will check trafic with my oscilloscope.
-
@pixelpieper your LCD detect sdcard?
Maybe the problem is related to CD(card detect) pin 2.4 exp2 in LCD with no way to duet.