Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    Firebox LCD Driver for LCDProc

    Scheduled Pinned Locked Moved Hardware
    398 Posts 97 Posters 508.9k Views 2 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • F Offline
      fmertz
      last edited by

      @stephenw10:

      IMHO there should be an option to enable the backlight permanently. Have the timer enabled by default with a warning perhaps.

      However long the backlight should last there are quite a few reports of X-core boxes with dead backlights!   ;)

      FWIW, the decision not to leave the light on is based on this spec. As the code is based on said spec, I assume it applies to our boxes. Then again, things could have changed over various models and hardware revisions.

      http://www.ktechs.net/pvt_filz/lcdproc/LMC-S2D20-01.pdf

      Based on a half-life as low as 3,000 Hrs (depending on how you read the spec, 30,000 Hrs is also listed), the prudent thing to do is to leave the light off unless a button is pressed (a proxy for knowing when a human is around to see it). I am open to suggestions to work around this apparent limitation, but I want to keep this code as free of hacks as possible so I can keep it acceptable for inclusion in the upstream lcdproc project.

      1 Reply Last reply Reply Quote 0
      • F Offline
        fmertz
        last edited by

        @flecom:

        going to look into that Arm/Disarm LED thing…

        The code on github has the logic for LED control built-in. It is meant to support all known models, but it has not been tested adequately just yet. The idea is that the code captures the many posts revealing the technical implementation details that have been painstakingly discovered over the years. The catch is that, as of now, there is no lcdproc client that uses that functionality. The lcdproc server only offers the "output" function, with the semantics and implementation left for the driver to decide.

        For testing, read this prior post:

        http://forum.pfsense.org/index.php/topic,44034.msg247112.html#msg247112

        Keep us posted.

        1 Reply Last reply Reply Quote 0
        • N Offline
          ninjamick
          last edited by

          hi all im new to linux and  pfsence  i got a  wg x700  and im tring to install pfsence with a  working  display  is there a version i can  get  that will work  without  adding extra scripts  as im  rubbish at  commands    so  help would be  greatful  as there is  very little  on the web  which  works with  windows  please help  :-[

          1 Reply Last reply Reply Quote 0
          • stephenw10S Offline
            stephenw10 Netgate Administrator
            last edited by

            You can get the LCD working entirely from the webgui using the LCDproc-dev package which can be found in the pfSense package system. However it currently fails to start correctly at boot on some models. You can manually start it from the webgui though.
            Working from the command line is not that difficult. If you acces the box via SSH (using putty) you can copy and paste commands which is even easier.  :)

            Just a quick note; pfSense is not Linux. It's build on FreeBSD. Both are equally different to Windows though.

            Steve

            1 Reply Last reply Reply Quote 0
            • stephenw10S Offline
              stephenw10 Netgate Administrator
              last edited by

              I had a few free hours to try again to get a working startup script for the lcdproc-dev package, and again failed.  :(
              Since it doesn't seem to be easily fixable (by me anyway) I have devised a method for running the new driver using the default lcdproc client. Because it's outside the package system it doesn't fall foul of the rapid start-stop sequence at boot. Anyway I have tested this on all the Watchguard boxes I have here, X-Core, X-Peak, X-e and XTM5 and it works fine.

              It has a number or advantages over the lcdd5.tar package:
              It uses fmertz's excellent rewritten driver with keyboard support for all models.
              It runs on 2.1.
              It survives a firmware update (I tested 2.0.2 > 2.0.3 and 2.1 snapshot update).
              It integrates with the Status: Services: screen.

              Unlike the lcdproc-dev package it doesn't crash every few hours but you don't get the choice of screens offered by the php client.

              Anyway I'd welcome any other testers:

              1. Install the lcdproc-dev package.
              2. In the Services: LCDproc: Server: screen select:
                 'Enable LCDproc at startup' yes
                 Com port - Parallel Port 1
                 Display Size - 2x20
                 Driver - Watchguard Firebox with SDEC
                 Hit the save button at the bottom.
              3. Doing the above generates the lcdd.conf file we need but it is only temporary so we need to copy it somewhere more permanent.
                 Go to Diagnostics: Command Prompt and run:

              cp /usr/local/etc/LCDd.conf /conf
              

              You could also run that at the CLI but via the webgui takes care of remounting the filesystem for you.
              4. No go back to Services: LCDproc: Server: , uncheck 'Enable LCDproc at startup' and set Com Port to 'none'. You must set the com port as none, that's what the lcdproc-dev config script looks for before it removes the RC start-stop scripts.
              5. Install the Shellcmd package if you haven't already.
              6. Add the following shell commands to start the lcdproc server and client:

              /usr/bin/nice -20 /usr/local/sbin/LCDd -r 0 -c /conf/LCDd.conf > /dev/null &
              
              /usr/bin/nice -20 /usr/local/bin/lcdproc C T U & 
              

              Both are type 'shellcmd'. You can choose which screens to display, C T U works for me. See my attached screenshot from an X-e box.
              7. Reboot. Or run those two commands manually.

              Steve

              Shellcmd2.png_thumb
              Shellcmd2.png

              1 Reply Last reply Reply Quote 0
              • B Offline
                Basiliss
                last edited by

                I am a bit confused. I've installed the LCDProc package through the PFSense 2.0.3 web interface and tried to follow the above instructions, but I couldn't find the "Driver - Watchguard Firebox with SDEC" option.
                Should I manually install a specific driver for Firebox, in order to appear in the driver options?

                1 Reply Last reply Reply Quote 0
                • stephenw10S Offline
                  stephenw10 Netgate Administrator
                  last edited by

                  You need the lcdproc-dev package not the original lcdproc package. Only the dev version has the newer drivers.

                  Steve

                  1 Reply Last reply Reply Quote 0
                  • B Offline
                    Basiliss
                    last edited by

                    @stephenw10:

                    You need the lcdproc-dev package not the original lcdproc package. Only the dev version has the newer drivers.

                    Steve

                    I see..thanks  :)

                    1 Reply Last reply Reply Quote 0
                    • B Offline
                      browntown
                      last edited by

                      @stephenw10:

                      1. Install the lcdproc-dev package.
                      2. In the Services: LCDproc: Server: screen select:
                          'Enable LCDproc at startup' yes
                          Com port - Parallel Port 1
                          Display Size - 2x20
                          Driver - Watchguard Firebox with SDEC
                          Hit the save button at the bottom.
                      3. Doing the above generates the lcdd.conf file we need but it is only temporary so we need to copy it somewhere more permanent.
                          Go to Diagnostics: Command Prompt and run:

                      cp /usr/local/etc/LCDd.conf /conf
                      

                      You could also run that at the CLI but via the webgui takes care of remounting the filesystem for you.
                      4. No go back to Services: LCDproc: Server: , uncheck 'Enable LCDproc at startup' and set Com Port to 'none'. You must set the com port as none, that's what the lcdproc-dev config script looks for before it removes the RC start-stop scripts.
                      5. Install the Shellcmd package if you haven't already.
                      6. Add the following shell commands to start the lcdproc server and client:

                      /usr/bin/nice -20 /usr/local/sbin/LCDd -r 0 -c /conf/LCDd.conf > /dev/null &
                      
                      /usr/bin/nice -20 /usr/local/bin/lcdproc C T U & 
                      

                      Both are type 'shellcmd'. You can choose which screens to display, C T U works for me. See my attached screenshot from an X-e box.
                      7. Reboot. Or run those two commands manually.

                      Steve

                      Thanks for this, I've been fighting problems with lcdproc for a while.  For reference for anyone that is curious as to what other screen flags you can use (from lcdproc doc)
                      lcdproc - LCDproc system status information viewer

                      Copyright © 1999-2006 Selene Scriven, William Ferrell, and misc. contributors.
                      This program is released under the terms of the GNU General Public License.

                      Usage: lcdproc [<options>] [ <screens>…]
                        where <options>are
                          -s <host>          connect to LCDd daemon on <host>-p <port>          connect to LCDd daemon using <port>-f                  run in foreground
                          -e <delay>          slow down initial announcement of screens (in 1/100s)
                          -c <config>        use a configuration file other than /etc/lcdproc/lcdproc.conf
                          -h                  show this help screen
                          -v                  display program version
                        and <screens>are
                          C CPU              detailed CPU usage
                          P SMP-CPU          CPU usage overview (one line per CPU)
                          G CPUGraph          CPU usage histogram
                          L Load              load histogram
                          M Memory            memory & swap usage
                          S ProcSize          biggest processes size
                          D Disk              filling level of mounted file systems
                          I Iface            network interface usage
                          B Battery          battery status
                          T TimeDate          time & date information
                          O OldTime          old time screen
                          U Uptime            uptime screen
                          K BigClock          big clock
                          N MiniClock        minimal clock
                          A About            credits page

                      Example:
                          lcdproc -s my.lcdproc.server.com -p 13666 C M X</screens></config></delay></port></port></host></host></options></screens></options>

                      1 Reply Last reply Reply Quote 0
                      • stephenw10S Offline
                        stephenw10 Netgate Administrator
                        last edited by

                        Ah intersting, are you using a server on a different machine? What does X show? Is that just the example from the help file?  ::)

                        Steve

                        1 Reply Last reply Reply Quote 0
                        • D Offline
                          dwfa
                          last edited by

                          I installed pfSense 2.1.1 to fix other issues I was having and was following the instructions to get the LCD working and it seems to hang when installing lcdproc-0.5.6-i386.pbi.  It has downloaded the filed and it just sits there extracting.  I went to the command line and noticed bsdtar is in the state biowr (writing) and consumes about 1% constantly (seems odd).

                          I had no issues installing this package on 2.1.  Not sure it is just my environment or not; thought I would put this out there.

                          EDIT:

                          I decided to let this run for some time.  It took very long > 15mins (went for a bite to eat), is this normal?

                          1 Reply Last reply Reply Quote 0
                          • stephenw10S Offline
                            stephenw10 Netgate Administrator
                            last edited by

                            Writing to the CF card can be exceptionally slow! I have experienced long delays re-installing packages though I'm not sure it was 15mins. Upgrading my test box from 2.1 to 2.1.1 took a while reload packages, including lcdproc-dev, but I'm unsure how long since I shot myself in the foot with a bad config.

                            Steve

                            1 Reply Last reply Reply Quote 0
                            • D Offline
                              dwfa
                              last edited by

                              Thanks for the info.  I know they can be slow; it was not this slow when I was using 2.1 - I will chalk it up to an  outlier condition  ;D.

                              1 Reply Last reply Reply Quote 0
                              • P Offline
                                power_matz
                                last edited by

                                Hi.

                                If you set the "Refresh frequency" before you copy the conf file this value will also be used by the new driver.
                                May someone needs more time per screen….

                                1 Reply Last reply Reply Quote 0
                                • stephenw10S Offline
                                  stephenw10 Netgate Administrator
                                  last edited by

                                  Yes it should do. That's part of the standard lcdproc configuration independent of the driver so it'd not hard coded or anything.

                                  Steve

                                  1 Reply Last reply Reply Quote 0
                                  • ? Offline
                                    A Former User
                                    last edited by

                                    Hello,

                                    i've just installed the lcdproc-dev package. I works so far, but after 30sek the backlight turned off.
                                    In the webgui Services > LCDproc > Backlight > On
                                    In the LCDd.conf is a line "Backlight=on" So it should work, but it doesn't.

                                    Any ideas?

                                    Thanks.

                                    1 Reply Last reply Reply Quote 0
                                    • stephenw10S Offline
                                      stephenw10 Netgate Administrator
                                      last edited by

                                      That's the normal behaviour.
                                      The backlight is hardcoded to turn off. The decision to do that was based on datasheets for the LCD module in the orginal X-Core box which stated the backlight life as limited number of hours (a few years) and that many of those boxes alreday had a dead backlight. Several people have requested it be allowed to stay on, which seems reasonable given the more recent modules have led backlights with a very long life, but that hasn't made it into the code.

                                      Steve

                                      1 Reply Last reply Reply Quote 0
                                      • ? Offline
                                        A Former User
                                        last edited by

                                        Hello Steve,

                                        thanks for your fast answer.

                                        Too bad. I hoped, to let the backlight always on.
                                        If i didn't use the LCDproc the backlight is always on, but it shows this annoying "Booting OS…"

                                        pyro

                                        ps. runnung pfsense on a X1250e

                                        1 Reply Last reply Reply Quote 0
                                        • stephenw10S Offline
                                          stephenw10 Netgate Administrator
                                          last edited by

                                          You could try something horrible like adding a cronjob to set the backlight on every 20s. No idea how it might interfer with the LCD driver though.  :-
                                          Or you could fork the driver and remove the code that turns it off.  ;)

                                          Steve

                                          1 Reply Last reply Reply Quote 0
                                          • R Offline
                                            ridnhard19
                                            last edited by

                                            Wow… This is crazy to see how my original proof of concept driver has taken off to a regular package and driver. I guess I lost track of all of this after mine died. It's nice to see people still using this hardware and the neat enhancements made. It's great for us as these devices are useless to many once they don't renew the licenses.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.