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

    Can't reach max turbo CPU frequency

    Scheduled Pinned Locked Moved Hardware
    15 Posts 5 Posters 2.5k Views 4 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.
    • C Offline
      Conjurer @stephenw10
      last edited by

      @stephenw10
      Thanks for your reply. Yes, enabling C states and before that I changed the following parameters in BIOS to allow the CPU to fully boost:

      • TDC Current Limit: 640
      • AC Loadline: 180
      • Tcc Activation Offset: 15 (limit 85 °C)
      • Tcc Offset Time Window: 3 secconds
      • Power limit 1: 55W
      • Power limit 2: 55W
      • Power Limit 1 Time Window: 28 seconds

      The factory BIOS was very crippled. The Speed Shift option was not available, but manufacturer tells me it's enabled by default. Well yes, but it's pointing to the wrong offset in NVRAM (how?!). So with some analysis I got the correct offset and modified the UEFI NVRAM and switched it to 01. Also changed the menu-structure a bit, so that I could both have access to the limited factory options (with the C states option) as well as the advanced options (above mentioned settings and more).

      However I'm not planning to run dev.hwpstate_intel.[0..11].epp to 0 at all times, that would be a waste of energy. I will make a simple script and cron it to switch between for example 35, 50, 75 and 95 depending on time of day. For example, I will be running on 95 at night, limiting power usage. By the way I could not find any documentation about thresholds related to the dev.hwpstate_intel.[0..11].epp setting. I know 0 is max. performance and 100 is max. energy efficiency, but how do all the values in between relate to CPU frequency?

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

        Good question. The man page doesn't show anything further.
        Probably buried in the Intel docs somewhere.
        The only hardware I have that supports it I have set at 80. That gives a pretty good result.

        1 Reply Last reply Reply Quote 0
        • C Offline
          Conjurer
          last edited by

          Oh and I had to set loader tunable machdep.hwpstate_pkg_ctrl to 0 (default is 1) in a newly created file /boot/loader.conf.local. When using the default value 1 for machdep.hwpstate_pkg_ctrl and setting epp for all cores to 0, the P-cores would stay at ~2780 MHz.

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

            Yes we have that as the recommended setting in the new gui options that will be in 23.09.

            It's hard to measure it though since simply running sysctl causes the CPU(cores) to ramp up. 😉

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

              @Conjurer I'm in setting up a new CWWK i7-1265u with pfSense 23.09 using fta's 6/8/2023 BIOS . I have got speed shift appearing to work with one quirk that I can't find an answer to:

              CPU Type 	12th Gen Intel(R) Core(TM) i7-1265U
                              Current: 2806 MHz, Max: 2688 MHz
                              12 CPUs
                              AES-NI CPU Crypto: Yes (active)
                              IPsec-MB Crypto: Yes (active)
                              QAT Crypto: No
              

              That screen capture was with speed Shift active and a Core Level control power preference setting of 30. The 2688 Mhz response looks suspicious, see dev.cpu freq_levels below.

              A "sysctl -a dev.cpu | grep cx" for cpu 0 shows:
              dev.cpu.0.cx_method: C1/mwait/hwc C2/mwait/hwc C3/mwait/hwc
              dev.cpu.0.cx_usage_counters: 221121 1637025 8068774
              dev.cpu.0.cx_usage: 2.22% 16.49% 81.28% last 477us
              dev.cpu.0.cx_lowest: C8
              dev.cpu.0.cx_supported: C1/1/1 C2/2/127 C3/3/1048

              A freq_levels response shows:
              dev.cpu.0.freq_levels: 2688/-1

              I was expecting more freq_levels and not a -1 response for the mW value. Is there a BIOS setting I'm missing?

              Edit:
              with power preference setting of 0:
              12th Gen Intel(R) Core(TM) i7-1265U
              Current: 4776 MHz, Max: 2688 MHz

              The 4776 MHz is expected. I don't understand the 2688 MHz max.

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

                AFAIK the frequency levels show there are for speedstep or other OS control methods. You won't see anything there unless powerd is enabled and SpeedShift replaces that.

                Those values are passed from the BIOS when speedstep is enabled. -1 indicates no mW value was passed.

                1 Reply Last reply Reply Quote 0
                • C Offline
                  Conjurer @Guest
                  last edited by

                  @rschell said in Can't reach max turbo CPU frequency:

                  sysctl -a dev.cpu | grep cx

                  Well to be honest, I don't know either where the Max: 2688 MHz is coming from. I just ignore it, and focus on the values presented as current. As for all other readings you posted, I have the same.

                  As @stephenw10 mentions, if you disable Speed Shift (loader tunable hint.hwpstate_intel.0.disabled), and enable SpeedStep (PowerD) you'll see various frequencies when performing sysctl -a dev.cpu | grep 'freq_levels\|freq'. But I wouldn't recommend it, Speed Shift is much more responsive and you can't fully utilize the pontential of this generation of Intel processor with SpeedStep.

                  1 Reply Last reply Reply Quote 1
                  • C Offline
                    Conjurer
                    last edited by Conjurer

                    @rschell Maybe of any help or just sharing my knowledge: I found that using command stress would give me best results when it comes to testing boost speeds. In combination with using cpuset for targeting specific cores (P-cores and/or E-cores).

                    Installing stress:

                    pkg install stress
                    rehash
                    

                    Command cpuset -l 0-3 stress -c 4 would (if hyper-threading is enabled) stress both P-cores with 4 worker processes.

                    1 Reply Last reply Reply Quote 1
                    • T Offline
                      Tiraga @Conjurer
                      last edited by

                      @Conjurer Hi, would it be possible to get information how you enabled Speed Shift in the bios? So far i could get the option Intel(R) Speed Shift Technology Interrupt Control to show up in the bios menu but enable or disable it doesn't change a thing. For HWP i got the following options: HwP Autonomous Per Core P State, HwP Autonomous EPP Grouping, HwP Fast MSR Support & HwP Lock but couldn't activate SST with those either.

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

                        You don't see the hwpstate_intel device detected in the boot logs?

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