-
Notifications
You must be signed in to change notification settings - Fork 33
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Different color codes for HP OMEN 870-155ng ? #3
Comments
There's a lot of Omen models and they all behave differently, so there's a whole bunch of logic in Omen Command Center just to figure out how exactly to control the device it's running on. Half the reason I haven't done a lot with this is simply because I have to replicate that logic and it's really dull! So it doesn't surprise me if things don't work right on any other model than the one I have. I do recall seeing some references to animation controls, which don't do anything on my machine but probably do on yours. As for seeing red rather than green - what happens when you try to set red or blue? It'd probably be something simple like the offset in the data buffer being wrong, but close. |
So have you got a hint for me, how to reverse engineer / find out addresses / values for my model? How did you do for yours? P.S. I still have a Windows installation on that machine if it is required, but no developer tools / debugger for Windows. |
Omen Command Centre is a C# application, so it decompiles extremely cleanly with ILSpy. Reading the resulting decompiled source code provided all the details. The trick is to actually find where it's hiding under Windows, which under C:/Program Files/WindowsApps/AD2F1837.OMENCommandCenter_SOMELONGVERSIONSTRINGTHATCHANGESCONSTANTLY/win32. |
There's a half-dozen different lighting types all referred to via codenames (Drax/Typhon/Perseus/Orisa/Tracer/aaargh) so it helps to know what your machine is identified as. You can do this by looking for the product id using
The 4 digit number after Product Name is what OCC uses, and it looks it up in a json file buried in HP.Omen.DeviceLib.dll. |
@pelrun Which one do you have? I can confirm that the LED control works perfectly fine on my 15-dc1031nm (other than middle and right zones having their colors a bit off, such as having a green tint on 0xFFFFFF, but I haven't confirmed whether that's a hardware issue, something to do with a difference brightness since I'm not able to change it, or something to do with color control in the module). |
I've got a 15-dh0146tx laptop, which has the FourZone lighting type. I haven't fiddled with the keyboard much of late (I'd rather use my mechanical while I'm stuck working from home) but I wouldn't be surprised if the colours are a bit off when controlling them directly. RGB LEDs aren't great for colour accuracy, and the OCC application might be doing colour correction itself. |
@geekq, I've recently had some success coming at the lighting from the other direction, decompiling the ACPI bytecode that is the layer between the kernel module and the hardware itself - it turns out to be a hell of a lot easier than trying to figure things out from the application. If you want to give me a dump of your acpi tables, I can have a look at them and see how it differs from mine and @wl2776's machines. The command is |
@pelrun This is mine omen laptop 15 2020, I give you a link of my acpidump. |
@ivan-boginski Thanks! Is there something not working as expected on your unit? Your dump indicates it should support the exactly the same LED interface that the module is using. |
@pelrun Thanks, I didn't try actually. I have tried, now it works perfectly, Someday I will probably make a simple gui app to control this without googling about the colors. |
the current location for Command Centre & its' modules is as follows:
|
@pelrun my model is an 15z-en100 2L1F0AV with FourZones lighting. 5800hx w/3070 running win10. Currently working with @CalcProgrammer1 on OpenRGB-Issue790, and need some files for OpenRGB to work with this model. So far, I've found that the LightStudio code looks like so: OpenRGBFuckery.zip |
I have got an HP tower "HP OMEN 870-155ng".
I've installed the module as follows:
(tested with Ubuntu Mate 20.04)
Now I can see the devices:
While by default the front panel light rotates colors changing it every couple of seconds,
writing to the zone device definitely changes the behavior.
So the new module somehow works!
Now the color rotation has stopped and the light has turned to pure red.
But I would like to have it green!
Looks like color encoding somehow differs for my model?
Do you have any ideas how to reverse engineer the values for my device or what to try out?
The text was updated successfully, but these errors were encountered: