Jump to content

Recommended Posts

Posted (edited)

Hello!

 

Just wondered if an armbian image was planned for the Odroid M1S?

 

Thank you in advance!

Edited by Nopraz
Posted (edited)

Hi,

I'd also like to see armbian running on my M1S.

It arrived today and honestly I ordered it in the hope to see it being supported one day.

Afaik none of the devs currently own an M1S yet, what makes development somewhat more difficult. So I would be happy to contribute by providing my M1S for tests.

So if anyone without an own M1S can provide an Armbian image with modified device tree and so on I will try to perform the desired tests.

 

Cheers and thank you!

Edited by Jojo
Posted (edited)

Hey guys,

 

looks like the devs are heavily busy with other stuff. As we can read they are currently massively struggling with a lack of ... basically everything. So let's try to support them by helping ourselves and share it with the community :) .

I have not read anything anywhere about an approach to create an Armbian image for the M1S, so lets try to sum up, what we have and what is needed.

I am really not an expert in all that - really NOT! But I like to contribute as far as I can!

 

I've read somewhere that someone has tried to boot the M1 image on a M1S which kind of "worked" surprisingly, but failed in many ways like HDMI output and so on. This makes me think that the required modifications are mainly regarding entire hardware definitions - the device tree.

There is already an official Home Assistant image for the M1S where the most changes are also regarding the device tree (see link above).

 

So my idea for the next steps would be:

  1. take the M1 Armbian image as a starting point
  2. replace the Device tree be the one from Home Assistant and see if/how far it starts.

 

Does this approach make sense and has it chance to work?!

 

The problem I have: when I download the Home Assistant image and mount it locally I just can not find any DTB file. The same applies to the M1 Armbian image. Does anyone know where to find the DTB files right after downloading the images?

 

Let's bring this forward guys. We have a sound software base to start from and the omnipotent Armbian build system. If we get people onboard who know better about the bootloader/device tree stuff than me, we should be able to do it :) .

 

Cheers

 

 

Edited by Jojo
Posted (edited)

Just to demonstrate what such a concern would mean for the distribution of my choice:

The only thing in OS space that is really device-specific is the devicetree, which describes how the device is wired. For the linux kernel, it is only relevant that the corresponding drivers for the components listed in the devicetree are also built using the necessary options. Since the drivers for the rk3568 SoC are the same as for the rk3566 SoC (they are wired differently only through the devicetree), there is no need for any special action in this case.
So all I'm missing is a mainline binding compliant devicetree, and I'm done.
Now all that's missing is a firmware that can start the OS of choice. And this contains device-specific code that can't be copied from another device, and must be built specifically for this device.
Fortunately, everything necessary has already been posted on the U-Boot mailing list. The devicetree used still has shortcomings, but it is a start.
In order to verify the handling of different binary bloobs with my build system, I already build the firmware regularly. It's also included in my provided firmware uploads, but I haven't communicated it as I don't own an ODROID-M1S and therefore can't verify its functionality.
For me, the conlusion means:
- Install the firmware

dd bs=512 seek=64 conv=notrunc,fsync if=odroid-m1s-rk3566/u-boot-rockchip.bin of=/dev/${entire-device-to-be-used}

- run the ODROID-M1S in UMS mode and tranfer my current image to a NVME
- Since there is no proper mainline devietree, I would use the one that falls off  during the firmware build and copy it in

cp /somewhere/rk3566-odroid-m1s.dtb /usr/lib/modules/linux/dtb/rockchip/rk3566-odroid-m1s.dtb

And I'm ready to rumble.
The same should be able to work with an Armbian ODROID-M1 image.

Edited by usual user
Correction of the DT filename, it is of course the DTB that needs to be copied.
Posted

Yes, so basically my approach is not that wrong to overcome the differences between M1 Armbian image and M1S by using the correct device tree.

 

7 hours ago, usual user said:

Fortunately, everything necessary has already been posted on the U-Boot mailing list. The devicetree used still has shortcomings, but it is a start.

I dont know the shortcomings you talk about, but AFAIK the device tree used by Home Assistant is fine and works stable, see HERE.

 

I also got told that I would have to rebuild the u-boot for the M1S (basically what you also said by referring to the firmware to flash).

 

Is there anything I miss or that I just understand wrong?

How to build the firmware for the M1S?

 

Sorry for asking so many dumb questions. All this is just far beyond my knowledge and I have never built a firmware - only a kernel with a detailed description 😅. I try to understand what is missing and how we can pull things together without re-inventing the wheel.

 

Cheers

Posted (edited)

Alright, continuing talking to myself I think I will try to make a build for the OrangePi 3b, because this way I assume to get a mainline compatible u-boot for the RK3566 as well as a recent kernel/file system . Then I will replace the device tree with that one from the M1S.

Any concerns? Of course not...

I will drop myself a note here if this was successful...

Edited by Jojo
Posted
12 hours ago, Jojo said:

What could be the next steps?

Since you have access to all the necessary components, grab an ODROID-M1 OS image of your choice, copy the components into it, and test.
If you install the OS image in the eMMC, be prepared to reinstall the original firmware. The ODROID-M1S does not have SPI flash and expects the firmware in the first instance in the eMMC. This means that the original firmware will be overwritten.
Alternatively, you can test with a microSD card, but you have to shortcircuit the MASK ROM pads each time at boot so that the firmware is loaded from there.
If you only transfer the firmware into the eMMC, you can also start the OS image of micrSD without MASK ROM intervention, this simplifies testing, because in  the OS image only the DTB has to be added and the OS image can be transferred to a microSD card more easily.

17 minutes ago, Jojo said:

I think I will try to make a build for the OrangePi 3b

Nothing has to be build in the first step by yourself, try testing the already availabe components.

Posted

Hey guys,

 

I just wanted to mention, that I have not forgotten this topic :) .

 

I just have currently no time to drive this further because of real-life stuff going. Additionally I currently have no hardware in spare which i could perform the tests on. So either you guys wait for a non-specified time or try something on your own.

 

So long... Cheers

Posted

Hi,

 

I have not much time either, but I would like to see an Armbian release for the M1S. I have one M1S unit with me I could use for testing, but I will have to share it with other tasks. Maybe I could help accelerate the process somehow, I just don't know where to start. I have been using Linux on embedded systems for some years, but never went very deep.

 

I have tried the linuxfactory bookworm image and it works, even with the Vu8S 8" display which connects to the MIPI connector. It must be installed to the onboard eMMC.

 

Does someone want to guide me on this? Or maybe supply ready to flash images I could test?

 

Posted

I think the m1s is an outstanding target. Very affordable and powerful. I own one, and I am available to test.

 

I would not know where to start in terms of adding a new target to Armbian, but I can help with testing.

Posted (edited)

Hi,

although this topic is quite old, I was trying to bring this forward.

I think I had a partial success on this. I've built an Armbian image with a newly created defconfig file. I took the DTB file from above.

Result:

  • the board seems to boot (SD card). The blue LED starts to blink (heartbeat).
  • Ethernet is working, I can SSH into the box.
  • USB seems to work, at least my Logitech Unifying Receiver is recognized

Problem: there is no HDMI output.

with dmesg | grep -i hdm I got the following output:

[    0.083861] /vop@fe040000: Fixed dependency cycle(s) with /hdmi@fe0a0000
[    0.083981] /hdmi@fe0a0000: Fixed dependency cycle(s) with /vop@fe040000
[    0.118236] /hdmi@fe0a0000: Fixed dependency cycle(s) with /hdmi-con
[    0.118360] /hdmi-con: Fixed dependency cycle(s) with /hdmi@fe0a0000
[    4.671032] dwhdmi-rockchip fe0a0000.hdmi: Detected HDMI TX controller v2.11a with HDCP (DWC HDMI 2.0 TX PHY)
[    4.675209] dwhdmi-rockchip fe0a0000.hdmi: registered DesignWare HDMI I2C bus driver
[    4.689857] rockchip-drm display-subsystem: bound fe0a0000.hdmi (ops dw_hdmi_rockchip_ops [rockchipdrm])

I dont know if this help. Maybe someone can assist?

 

@Igoreverybody here honors and respects you and your work and your effort. We (or at least me) do not expect you to bring up one after another working image for all boards out there. What we do is asking for help to help ourselves.

It is more than clear and obvious, that you are frustrated by the numerous apparent "requests" on one side and a massive lack of volunteering support on the other side.

BUT: for US it is also sometimes frustrating, that you try to end all those threads like this by saying "STFU, RTFM".

I am (and many more are) NOT those people, who just pass by to say "Hey Armbian, when do you finally support board XYZ?????????". Many of us TRY to contribute. But sometimes the tasks are just too hard to teach ourselves.

You do this on a daily basis. But for "beginners" building the first linux image is so damn challenging and especially when you are alone on the battlefield (like when trying to bring an unsupported board to life).

Yes, I read the docs. And yes, I already did before you restructured the build system. So asking for help is not intended to upset you.

And still, I don't expect any support from your side. We try to come as far as possible on our own. But maybe there has been a time, when even you needed some guidance which involved a little bit more than RTFM...

 

I respect and appreciate your work!

Edited by Jojo
Posted (edited)
6 hours ago, Jojo said:

I dont know if this help. Maybe someone can assist?

ODROID M1: dmesg | grep -i hdm

[    0.132185] /vop@fe040000: Fixed dependency cycle(s) with /hdmi@fe0a0000
[    0.132325] /hdmi@fe0a0000: Fixed dependency cycle(s) with /vop@fe040000
[    0.170085] /hdmi@fe0a0000: Fixed dependency cycle(s) with /hdmi-con
[    0.170254] /hdmi-con: Fixed dependency cycle(s) with /hdmi@fe0a0000
[    1.180141] dwhdmi-rockchip fe0a0000.hdmi: Detected HDMI TX controller v2.11a with HDCP (DWC HDMI 2.0 TX PHY)
[    1.181147] dwhdmi-rockchip fe0a0000.hdmi: registered DesignWare HDMI I2C bus driver
[    1.182413] rockchip-drm display-subsystem: bound fe0a0000.hdmi (ops dw_hdmi_rockchip_ops)

ODROID M2: dmesg | grep -i hdm

[    0.104853] /vop@fdd90000: Fixed dependency cycle(s) with /hdmi@fde80000
[    0.104911] /hdmi@fde80000: Fixed dependency cycle(s) with /vop@fdd90000
[    0.121323] /hdmi@fde80000: Fixed dependency cycle(s) with /hdmi-con
[    0.121364] /hdmi-con: Fixed dependency cycle(s) with /hdmi@fde80000
[    0.547910] dwhdmiqp-rockchip fde80000.hdmi: registered DesignWare HDMI QP I2C bus driver
[    0.548835] rockchip-drm display-subsystem: bound fde80000.hdmi (ops dw_hdmi_qp_rockchip_ops)

ODROID N2+: dmesg | grep -i hdm

[    0.079885] /soc/bus@ff600000/hdmi-tx@0: Fixed dependency cycle(s) with /soc/vpu@ff900000
[    0.080281] /soc/vpu@ff900000: Fixed dependency cycle(s) with /soc/bus@ff600000/hdmi-tx@0
[    0.080908] /soc/bus@ff600000/hdmi-tx@0: Fixed dependency cycle(s) with /soc/vpu@ff900000
[    0.081352] /soc/bus@ff600000/hdmi-tx@0: Fixed dependency cycle(s) with /soc/vpu@ff900000
[    0.090819] /soc/bus@ff600000/hdmi-tx@0: Fixed dependency cycle(s) with /soc/vpu@ff900000
[    0.090892] /soc/vpu@ff900000: Fixed dependency cycle(s) with /soc/bus@ff600000/hdmi-tx@0
[    0.097002] /soc/bus@ff600000/hdmi-tx@0: Fixed dependency cycle(s) with /hdmi-connector
[    0.097080] /hdmi-connector: Fixed dependency cycle(s) with /soc/bus@ff600000/hdmi-tx@0
[    0.561480] meson-dw-hdmi ff600000.hdmi-tx: Detected HDMI TX controller v2.01a with HDCP (meson_dw_hdmi_phy)
[    0.561810] meson-dw-hdmi ff600000.hdmi-tx: registered DesignWare HDMI I2C bus driver
[    0.562112] meson-drm ff900000.vpu: bound ff600000.hdmi-tx (ops meson_dw_hdmi_ops)

NanoPC-T6-LTS: dmesg | grep -i hdm

[    0.119431] /vop@fdd90000: Fixed dependency cycle(s) with /hdmi@fde80000
[    0.119475] /hdmi@fde80000: Fixed dependency cycle(s) with /vop@fdd90000
[    0.137536] /vop@fdd90000: Fixed dependency cycle(s) with /hdmi@fdea0000
[    0.137589] /hdmi@fdea0000: Fixed dependency cycle(s) with /vop@fdd90000
[    0.139716] /hdmi@fde80000: Fixed dependency cycle(s) with /hdmi0-con
[    0.139765] /hdmi0-con: Fixed dependency cycle(s) with /hdmi@fde80000
[    0.139922] /hdmi@fdea0000: Fixed dependency cycle(s) with /hdmi1-con
[    0.139960] /hdmi1-con: Fixed dependency cycle(s) with /hdmi@fdea0000
[    0.579865] dwhdmiqp-rockchip fde80000.hdmi: registered DesignWare HDMI QP I2C bus driver
[    0.580803] rockchip-drm display-subsystem: bound fde80000.hdmi (ops dw_hdmi_qp_rockchip_ops)
[    0.582184] dwhdmiqp-rockchip fdea0000.hdmi: registered DesignWare HDMI QP I2C bus driver
[    0.583115] rockchip-drm display-subsystem: bound fdea0000.hdmi (ops dw_hdmi_qp_rockchip_ops)

At all HDMI ports work perfectly.

And yes, they all use the same system booted from a USB enclosure.
The only difference is the loaded DTB at system startup.

Edited by usual user
Posted (edited)

@usual userWell, this was also my feeling that there might be something wrong with the device tree. The Hardkernel section for HDMI looks a little bit different compared to the HDMI section in the device tree I have used. I thought it would be kind of okay, because the kernel is a different one. But maybe this assumption was wrong...

So what could I do if I'd like to try the Hardkernel DTB? Is there a chance that it just works?

Or would it be the better way to create an device tree overlay? I don't know anything at all about that, sry...

 

EDIT:

Could there be other reasons? Like an deactivated video output option somewhere? Or maybe it need to be actively activated? Please let me know if I can provide further information, file contents or so...

Edited by Jojo
Posted

Booting from internal eMMC also works.

 

Regarding HDMI:

I've made another build where I pulled the DTS definitions for the M1S from the Linux mainline repository directly during compilation (thanks ChatGPT!).

But that also did not help. The system "works" as before, just no HDMI...

Posted
2 hours ago, Jojo said:

Booting from internal eMMC also works.

Just out of curiosity, are you able to run your device with firmware loaded from microSD?
I. e. firmware area on eMMC cleared. If so, you can try my kernel build and see how it works for you.

Posted
9 hours ago, usual user said:

Just out of curiosity, are you able to run your device with firmware loaded from microSD?
I. e. firmware area on eMMC cleared. If so, you can try my kernel build and see how it works for you.

To be honest I currently don't know.

I booted my first from SD card. That worked as described above.

After that, I've shut down the M1S, set the M1S to UMS mode and cloned the SD card to the internal eMMC. Booted as described.

But please tell me how to perform that test and I can give your kernel build a try :) .

 

Greetings

Posted

Okay, one step further: HDMI output is WORKING!

initially I had the M1S connected to the Aux input of my AV receiver. There seems to be a problem with display detection (EDID, available modes) and so the M1S does not know which display mode to set.

 

I then connected the M1S directly to an HDMI input of the TV and nothing changed. Rebooted and ... Surprise! Video output works, EDID information and available modes are available (wasn't when connected to AV receiver).

 

So how can I tell Armbian to force a specific display mode even when no screen information is available?

 

Posted
37 minutes ago, Jojo said:

So how can I tell Armbian to force a specific display mode even when no screen information is available?

Since you have now confirmed the HDMI functionality, the time has come for me to retire further support.
I am only interested in generic support; for Armbian-specific issues, you'll have to wait for others who are interested.

Posted
3 minutes ago, usual user said:

Since you have now confirmed the HDMI functionality, the time has come for me to retire further support.
I am only interested in generic support; for Armbian-specific issues, you'll have to wait for others who are interested.

Okay. Thank you!

Posted

M.2 NVMe slot is also WORKING. At least the SSD gets detected with "cat /proc/partitions". It is not listed under "df -h" but I think this is because it is not mounted yet...

Posted (edited)

Just compiled and flashed a Cinnamon desktop image.

  • Boots fine
  • Video over HDMI working.
  • Audio over HDMI working.

 

The video experience is not that much satisfying. There seems to be no graphic acceleration, yet. WebGL aquarium runs at 5 FPS with 500 fishes, 15 FPS with 100 fishes.

Youtube videos are relatively laggy and you'll experience high CPU load.

All the GPIO hardware stuff has not been tested, yet. No clue how to do it...

 

Now I'd like to have some more people on board to support me by adding graphic acceleration and how to merge the M1S support now into the Armbian repo.

 

Greetings.

 

EDIT 1:

transferring the OS from SD card do eMMC works by using armbian-install tool

 

EDIT 2:

graphic acceleration IS kind of working, glmar2-es2 gives me a score of ~177.

But the web browser seems not to be accelerated. also the desktop environment seems to have problems Cinnamon is not able to load applets, which means that the "Start" menue icon is missing...

Edited by Jojo
Posted
18 hours ago, Jojo said:

graphic acceleration IS kind of working, glmar2-es2 gives me a score of ~177.

In an XWindow environment, these are realistically expected numbers.
In a Wayland environment, this is somewhat better; see glmark2-wayland-odroid-m1.log as a reference.
But it is in no way comparable to a Mali G610; see glmark2-wayland-odroid-m2.log as a reference.

 

19 hours ago, Jojo said:

But the web browser seems not to be accelerated.

Use WebGL Report to be sure.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...
×
×
  • Create New...

Important Information

Terms of Use - Privacy Policy - Guidelines