Opened 4 years ago

Last modified 2 months ago

#16463 new bug

app_server: Use 2576x1118 (8) instead

Reported by: yangh Owned by: axeld
Priority: normal Milestone: Unscheduled
Component: Servers/app_server Version: R1/Development
Keywords: Cc:
Blocked By: Blocking: #14302, #15060, #16050, #16992, #17201, #17424
Platform: All

Description (last modified by yangh)

I'm trying to install Haiku into my new laptop, HP Envy x360 2020 AMD Ryzen R5 4700 + Radeon graphics card + 8G RAM.

I flashed the Nightly build 54487 into a USB 2.0 stick drive, disabled the secure boot in the BIOS, and the laptop booted into Haiku on the USB stick, but it stuck at the bootsplash and never show the desktop. USB 3.0 stick drive doesn't work neither.

I captured an image after enabled the debug log on screen. Please help to check what happened, if any new log needed, I can try to obtain more logs from the laptop.

Thanks

Attachments (12)

stuck-on-splash.jpg (1.4 MB ) - added by yangh 4 years ago.
log-on-screen.jpg (4.0 MB ) - added by yangh 4 years ago.
enabled-fail-safe-graphics-driver.jpg (2.9 MB ) - added by yangh 4 years ago.
Samiliar error printed on screen even enabled fail safe graphics driver
haiku-envy-x360-modes-dump.jpeg (1.4 MB ) - added by yangh 4 years ago.
radeon-hd-add-renoir-1636.patch (649 bytes ) - added by yangh 4 years ago.
Add device id for Radeon Renoir 1636 in Ryzen 2
IMG_20200930_223613R.jpg (2.9 MB ) - added by yangh 4 years ago.
radeon_hd driver starts to work after Add device id for Radeon Renoir 1636 in Ryzen 2
IMG_20200930_223619R.jpg (3.4 MB ) - added by yangh 4 years ago.
radeon_hd driver PANIC in radeon_hd_init()
IMG_20201001_210238R.jpg (2.4 MB ) - added by yangh 4 years ago.
Added a while(true); before the panic()at arch/x86/arch_vm.cpp, enabled arch vm trace so we have more log in the screen.
IMG_20201001_220321R.jpg (2.1 MB ) - added by yangh 4 years ago.
As you said, The mtrr error could be ignored. Now it runs in to a new issue, atom bios on the gpu is not found.
syslog55780 (184.8 KB ) - added by pragmavalue 3 years ago.
syslog.zip (128.0 KB ) - added by dpirate 3 years ago.
dpirate_syslog (219.1 KB ) - added by korli 2 years ago.
dpriate syslog from syslog.zip

Change History (42)

by yangh, 4 years ago

Attachment: stuck-on-splash.jpg added

by yangh, 4 years ago

Attachment: log-on-screen.jpg added

comment:1 by yangh, 4 years ago

Description: modified (diff)

comment:2 by waddlesplash, 4 years ago

Component: - GeneralServers/app_server
Owner: changed from nobody to axeld

Can you try enabling "use fail safe video mode" in the bootloader? This may be an appserver bug however...

by yangh, 4 years ago

Samiliar error printed on screen even enabled fail safe graphics driver

in reply to:  2 comment:3 by yangh, 4 years ago

Replying to waddlesplash:

Can you try enabling "use fail-safe video mode" in the bootloader? This may be an appserver bug however...

The log shows that no supported devices found for both radeon_hd/i810 driver, then vesa init succeeded.

Does the 2576x1118 resolution mater?

comment:4 by yangh, 4 years ago

Hi Wad/axeld Any suggestion for debugging? Can I add some debug info and build a new hpkg to replace which one in USB stick, then boot the laptop with this USB stick for debugging?

Thanks Walter

comment:5 by waddlesplash, 4 years ago

I use Haiku with a 4K resolution larger than that, so it should not be a problem for app_server. I guess you can try a lower one and see if something different happens.

comment:6 by MelanieFox, 4 years ago

One Problem with Ryzens especially zen2 is a cpu bug when using vm8086 mode which the vesa driver relies on.

The only time Haiku ran on my baremetal way way ago when the radion drivers still worked and the efi framebuffer driver was responsible for splash.

i don't know if it helps or what happens then, but maybe you could try the don't call the bios option.

comment:7 by pulkomandy, 4 years ago

That video resolution of 2576x1118 seems a bit strange. There is another reference to it in #15036 but it seems to not be a standard one. A Google search shows some pages saying that would be the total horizontal/vertical sizes for a 1080p display (including hsync/vsync, porch and border areas). It is also strange that app_server is trying to use an 8bpp (256 colors) mode instead of 32bpp.

So it looks like we end up using the wrong part of the timing infos, or somehow what we get from VESA in terms of available video mode is not handled correctly.

I think it would help if you could share pictures of earlier screens in the boot log, in particular, near the start of the log, the VESA driver will dump the list of available video modes.

in reply to:  7 comment:8 by yangh, 4 years ago

Replying to pulkomandy:

So it looks like we end up using the wrong part of the timing infos, or somehow what we get from VESA in terms of available video mode is not handled correctly.

I've set up a virtual box env and succeeded to build Haiku x86_64 any boot iso, I can add some debug info into the VESA driver or app_server now.

How can I replace the haiku kernel? is it as easy as replacing the haiku_r1beta...hpkg in system/packages? I would like to replace some packages in the USB stick instead of flashing the iso for each updating.

I think it would help if you could share pictures of earlier screens in the boot log, in particular, near the start of the log, the VESA driver will dump the list of available video modes.

I enabled debug message on screen and disabled paging, then I check the logs on-screen line by line. There is no more message from VESA driver beside the Attachment: log-on-screen.jpg.

Thanks

comment:9 by pulkomandy, 4 years ago

Yes, you can simply replace the haiku package for testing a new version.

I guess it makes sense that the early logs from the vesa driver won't get to the on screen debug since they are logged before the screen is set up.

You may be able to enter KDL (alt + printscreen + d) and use the syslog command there to get the early part of the syslog, where the info should be available.

by yangh, 4 years ago

comment:10 by yangh, 4 years ago

I've dumped modes returned from fHWInterface->GetModeList(&modes, &count),

status_t Screen::SetBestMode(uint16 width, uint16 height, uint32 colorSpace,

float frequency, bool strict)

{

search for a matching mode display_mode* modes = NULL; uint32 count; status_t status = fHWInterface->GetModeList(&modes, &count);

Please refer to the haiku-envy-x360-modes-dump.jpeg​, the output shows that there are two mode available, both are 1920x1080, so could not matches 1024x768 or 800x600 from:

VirtualScreen::AddScreen(Screen* screen, ScreenConfigurations& configurations) {

screen_item* item = new(std::nothrow) screen_item; if (item == NULL)

return B_NO_MEMORY;

item->screen = screen;

status_t status = B_ERROR;

...

if (status != B_OK) {

status_t status = screen->SetPreferredMode(); if (status != B_OK)

status = screen->SetBestMode(1024, 768, B_RGB32, 60.f);

if (status != B_OK)

status = screen->SetBestMode(800, 600, B_RGB32, 60.f, false);

if (status != B_OK) {

debug_printf("app_server: Failed to set mode: %s\n",

strerror(status));

}

Then, I added a new mode before 1024x768:

if (status != B_OK)

status = screen->SetBestMode(1920, 1080, B_RGB32, 60.f);

Then it matched, but I still can't see the desktop, and the boot process stopped at the red rocket which is the same as before, the on-screen debug message stopped after the new mode matched.

Why haiku_loader could display normally and also the splash screen? Any suggestions for the next step?

Since this is a brand new CPU and GPU (embedded in the SoC), should I try to hack the Radeon driver?

Thanks Walter

comment:11 by MelanieFox, 4 years ago

Maybe you could try to peek how Linux does this. What irritates me is that radeon_hd should be responsible as far as i know thats the driver for far older models and radeon driver should be in charge.

Hopefully you stumble about some solutions, And maybe the even help me out.

in reply to:  11 comment:12 by pulkomandy, 4 years ago

Replying to MelanieFox:

What irritates me is that radeon_hd should be responsible as far as i know thats the driver for far older models and radeon driver should be in charge.

?

radeon is the driver for older cards (radeon 7000 and 9250, that kind of things from the early 2000s) and radeon_hd is for the new ones.

Anyway, app_server will just try all accelerants when starting, until one finds that a matching driver is loaded, and use vesa/frambuffer if no driver is loaded. So it's not unexpected to get logs from all the accelerants as this is done during init.

In this case here the card is probably too new and not handled yet by the radeon_hd driver. And so we try vesa/framebuffer but we are not too succesful with that either.

comment:13 by MelanieFox, 4 years ago

Okay. Thx. for the elaboration. So it's basically the other way around like

with Linux and such.

Well vesa with it's bios and vm86 Calls is a culprit since zen1 arch.

Don' expect to get meaningfull or correct data at all Times.

You might be lucky or not. Vesa on zen x works in virtualbox, vmware as lang as the fake resonable results, which they can with hostos data and never enter vm86 mode.

Vesa fb on linux on baremetal is also impossible for me. Pagefaults, Triple-Faults or obviously stupid data.

Stack corruptions... Well the CPU just don't behaves like specified.

An AGESA Update solves this problem. But only for WinXP +, BSD 10 Series, Linux 4.10+

For what reason ever getting the e820 map works pretty good. Most Times.

Maybe you could have this in mind.

Also an Intel CPU wothout that Bug and AmD graphics works like a Charme.

AMD only stated its possible to worl around via Software.

Most solutions avoid the Bug by stubbing vm86 or never ever even need this.

comment:14 by pulkomandy, 4 years ago

On 64bit Haiku we don't use vm86. We run the VESA BIOS inside a software emulator already. Does 32 vs 64bit Haiku make a difference then?

comment:15 by waddlesplash, 4 years ago

No, we do the same on 32bit; VM86 support was completely removed from the kernel years ago.

by yangh, 4 years ago

Add device id for Radeon Renoir 1636 in Ryzen 2

by yangh, 4 years ago

Attachment: IMG_20200930_223613R.jpg added

radeon_hd driver starts to work after Add device id for Radeon Renoir 1636 in Ryzen 2

by yangh, 4 years ago

Attachment: IMG_20200930_223619R.jpg added

radeon_hd driver PANIC in radeon_hd_init()

comment:16 by MelanieFox, 4 years ago

Weird. Could you check if there is some mtrr dump Debugger command? (Type help)

Maybe there are too many drivers using mtrr's insteat of Page Table Attributes and your CPU doesn't have enough of them?

I guess the panic occured when radeon_hd mapped the framebuffer and instructed the vm manager to set it to write combine via mtrr.

(topic vesa: sorry looked into the wrong source files. boot/vesa instead of the kernel driver)

comment:17 by yangh, 4 years ago

It seems that the last range with size 0x80000 (512M? 512K?) could not be set as MTRR.

by yangh, 4 years ago

Attachment: IMG_20201001_210238R.jpg added

Added a while(true); before the panic()at arch/x86/arch_vm.cpp, enabled arch vm trace so we have more log in the screen.

comment:18 by pulkomandy, 4 years ago

The MTRR problems are already mentionned in #5353 but from my understanding the only downside (for the use in graphics, at least) is that write combining will not be enabled, resulting in slow framebuffer). Is the panic continuable? (by just typing "continue" or "co" at the KDL prompt).

In that other ticket, there are discussions for using other mechanisms on Pentium 3 and later. Maybe it's time we start considering to use these. But in the meantime, from your logs, I'd say the setup could be improved as documented in that ticket (using a more complex but more intelligent combination of MTRR entries to achieve what we want).

by yangh, 4 years ago

Attachment: IMG_20201001_220321R.jpg added

As you said, The mtrr error could be ignored. Now it runs in to a new issue, atom bios on the gpu is not found.

comment:19 by diver, 3 years ago

Summary: HP Envy x360 2020 AMD Ryzen R4 4700 supportapp_server: Use 2576x1118 (8) instead

comment:20 by diver, 3 years ago

Blocking: 16992 added

comment:21 by diver, 3 years ago

Blocking: 17201 added

comment:22 by diver, 3 years ago

Blocking: 17424 added

comment:23 by diver, 3 years ago

Blocking: 15060 added

comment:24 by diver, 3 years ago

From #15060 it looks like enabling CSM could be a workaround.

Last edited 3 years ago by diver (previous) (diff)

comment:25 by diver, 3 years ago

Blocking: 14302 added

by pragmavalue, 3 years ago

Attachment: syslog55780 added

comment:26 by dpirate, 3 years ago

I have the same problem with a Radeon HD 6670 + 4K 27" LG screen. Haiku boots and then I get a black screen instead of the desktop. Enabling failsafe VGA works. The same card used to work fine with a Samsung Full HD 27" screen which was replaced with the LG 4K one.

comment:27 by korli, 3 years ago

dpirate, please attach a syslog

by dpirate, 3 years ago

Attachment: syslog.zip added

comment:28 by dpirate, 3 years ago

As I didn't know which syslog file is needed exactly I attached a zip file with everything that is in /var/log after reproducing the bug and restarting in failsafe mode.

by korli, 2 years ago

Attachment: dpirate_syslog added

dpriate syslog from syslog.zip

comment:29 by korli, 2 years ago

radeon_hd: ==========================================
radeon_hd: encoder_init: called
radeon_hd: transmitter_dig_setup: connector 0, pixelClock: 0
radeon_hd: transmitter_dig_setup: table 1.4
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: transmitter_dig_setup: connector 1, pixelClock: 0
radeon_hd: transmitter_dig_setup: table 1.4
radeon_hd: encoder_pick_dig: connector 1
radeon_hd: pll_asic_ss_probe: No potential spread spectrum data found!
radeon_hd: pll_set_external: set external pll clock to 540000
radeon_hd: pll_set_external: table 1.6
radeon_hd: dp_setup_connectors
radeon_hd: detect_displays: connector(0): bit-banging ddc for EDID.
radeon_hd: connector_read_edid: found edid monitor on connector #0
radeon_hd: detect_displays: connector(0): found EDID data.
radeon_hd: init_registers, registers for ATI chipset Turks crt #0 loaded
radeon_hd: detect_displays: connector(1): bit-banging ddc for EDID.
radeon_hd: detect_displays: connector(2): bit-banging ddc for EDID.
radeon_hd: Currently detected monitors===============
radeon_hd: Display #0 attached = true
radeon_hd:  + connector ID:   0
radeon_hd:  + connector type: HDMI A
radeon_hd:  + encoder type:   TMDS
radeon_hd:  + limits: Vert Min/Max: 56/61
radeon_hd:  + limits: Horz Min/Max: 30/135
radeon_hd: Display #1 attached = false
radeon_hd: ==========================================
radeon_hd: radeon_gpu_mc_setup: vramStart: 0x0, vramEnd: 0xFFFFFFF
radeon_hd: radeon_gpu_ring_setup called
radeon_hd: RingQueue: Requested 1048576 bytes for GFX RingQueue.
radeon_hd: RingQueue: Allocating 1048576 bytes for GFX RingQueue.
radeon_hd: radeon_gpu_ring_boot called
radeon_hd: radeon_gpu_ring_boot: TODO
radeon_hd: radeon_init_accelerant done
radeon_hd: radeon_get_edid_info
radeon_hd: radeon_get_preferred_mode
radeon_hd: radeon_get_edid_info
radeon_hd: radeon_accelerant_mode_count
radeon_hd: radeon_get_mode_list
radeon_hd: radeon_set_display_mode
radeon_hd:   mode->space: 0x8
radeon_hd:   mode->virtual_width: 3840
radeon_hd:   mode->virtual_height: 2160
radeon_hd:   mode->h_display_start: 0
radeon_hd:   mode->v_display_start: 0
radeon_hd:   mode->flags: 0x8000001f
radeon_hd: encoder_output_lock: true
radeon_hd: display_crtc_lock
radeon_hd: encoder_dpms_set: display 0, power: false
radeon_hd: encoder_dpms_set_dig: display 0, power: false
radeon_hd: transmitter_dig_setup: connector 0, pixelClock: 0
radeon_hd: transmitter_dig_setup: table 1.4
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: display_crtc_dpms: crtc 0 dpms powerdown
radeon_hd: display_crtc_blank
radeon_hd: display_crtc_memreq
radeon_hd: display_crtc_power
radeon_hd: encoder_assign_crtc
radeon_hd: encoder_assign_crtc: table 1.2
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: encoder_crtc_scratch: display 0
radeon_hd: radeon_set_display_mode: pll 0 selected for connector 0
radeon_hd: pll_asic_ss_probe: No potential spread spectrum data found!
radeon_hd: pll_setup_flags: CRTC: 0, PLL: 0
radeon_hd: pll_adjust: table 1.3
radeon_hd: pll_adjust: was: 594000, now: 297000
radeon_hd: pll_compute_post_divider: using AtomBIOS post divider
radeon_hd: pll_compute: using AtomBIOS reference divider
radeon_hd: pll_compute: using AtomBIOS fractional feedback divider
radeon_hd: pll_compute: Calculated pixel clock of 297000 based on:
radeon_hd: pll_compute:   referenceFrequency: 27000; referenceDivider: 1
radeon_hd: pll_compute:   feedbackDivider: 44; feedbackDividerFrac: 0
radeon_hd: pll_compute:   postDivider: 4
radeon_hd: pll_set: table 1.6
radeon_hd: pll_set: set adjusted pixel clock 594000 (was 594000)
radeon_hd: display_crtc_ss
radeon_hd: display_crtc_set_dtd called to do 3840x2160
radeon_hd: display_crtc_fb_set: Framebuffer at: 0x0
radeon_hd: display_crtc_fb_set: Set SurfaceAddress High: 0x0
radeon_hd: display_crtc_fb_set: Set SurfaceAddress: 0x0
radeon_hd: display_crtc_fb_set: fb: 3840x2160 (32 bpp)
radeon_hd: display_crtc_fb_set: fb pitch: 3840 
radeon_hd: display_dce45_crtc_load_lut: crtcID 0
radeon_hd: display_crtc_scale
radeon_hd: encoder_mode_set: display 0
radeon_hd: encoder_dig_setup
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: encoder_dig_setup: table 1.4
radeon_hd: encoder_dig_setup
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: encoder_dig_setup: table 1.4
radeon_hd: encoder_apply_quirks: display 0
radeon_hd: display_crtc_dpms: crtc 0 dpms powerup
radeon_hd: display_crtc_power
radeon_hd: display_crtc_memreq
radeon_hd: display_crtc_blank
radeon_hd: encoder_dpms_set: display 0, power: true
radeon_hd: encoder_dpms_set_dig: display 0, power: true
radeon_hd: encoder_dig_setup
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: encoder_dig_setup: table 1.4
radeon_hd: encoder_dig_setup
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: encoder_dig_setup: table 1.4
radeon_hd: transmitter_dig_setup: connector 0, pixelClock: 594000
radeon_hd: transmitter_dig_setup: table 1.4
radeon_hd: encoder_pick_dig: connector 0
radeon_hd: display_crtc_lock
radeon_hd: encoder_output_lock: false
radeon_hd: Current DisplayPort Info =================
radeon_hd: Connector #0) DP: false
radeon_hd: Connector #1) DP: false
radeon_hd: Connector #2) DP: false
radeon_hd: ==========================================
radeon_hd: D1CRTC_STATUS        Value: 0x2
radeon_hd: D2CRTC_STATUS        Value: 0x0
radeon_hd: D1CRTC_CONTROL       Value: 0x0
radeon_hd: D2CRTC_CONTROL       Value: 0x0
radeon_hd: D1GRPH_ENABLE        Value: 0x0
radeon_hd: D2GRPH_ENABLE        Value: 0x0
radeon_hd: D1SCL_ENABLE         Value: 0x10F9F
radeon_hd: D2SCL_ENABLE         Value: 0x0
radeon_hd: D1CRTC_BLANK_CONTROL Value: 0x0
radeon_hd: D2CRTC_BLANK_CONTROL Value: 0x0
radeon_hd: radeon_get_frame_buffer_config
radeon_hd:   config->frame_buffer: 0xffffffffa2000000
radeon_hd:   config->frame_buffer_dma: 0xd0000000
radeon_hd:   config->bytes_per_row: 15360
radeon_hd: display_crtc_dpms: crtc 0 dpms powerup
radeon_hd: display_crtc_power
radeon_hd: display_crtc_memreq
radeon_hd: display_crtc_blank
radeon_hd: encoder_dpms_set: display 0, power: true
radeon_hd: encoder_dpms_set_dig: display 0, power: true
radeon_hd: encoder_dig_setup
radeon_hd: encoder_pick_dig: connector 0

comment:30 by diver, 2 months ago

Blocking: 16050 added
Note: See TracTickets for help on using tickets.