It makes sense that you would be a RISC giver rather than a risk taker. 🙂Thanks for sharing.
@CNLohr2 жыл бұрын
Oh I like that joke.
@ioinfinity Жыл бұрын
*\(^___^)/* 🐁
@lpcamargo2 жыл бұрын
So cool, the whole thing fits the L1 cache of a modern processor with lines and lines to spare 😎
@CNLohr2 жыл бұрын
Absolutely!
@ioinfinity Жыл бұрын
*\(^___^)/* 🦊
@GiveAcademy2 жыл бұрын
I understand the whole being excited about a project… reach a monumental milestone and then hit the unsure if you will continue or quit while ahead haha. This is great work and you are very inspiring!!! I hope your curiosity continues to fuel your excitement for this project. Where this goes will be a great adventure. Keep up the awesome content! I have a feeling your channel is on the cusp of massive growth! Again great job!
@CNLohr2 жыл бұрын
I did push it a litttle bit further, so I'm going to make at least one more video!
@ioinfinity Жыл бұрын
*\(^___^)/* 🐻
@Greeegification2 жыл бұрын
Nice work! A fun step with emulators is adding in a gdb server/hooks so you can debug your emulated processor with breakpoints and watched variables just like on real hardware.
@CNLohr2 жыл бұрын
I haven't gotten to it, but, that can totally be done using this emulator. The .h file can have overrides to facilitate this.
@ioinfinity Жыл бұрын
*\(^___^)/* 🐒
@ioinfinity Жыл бұрын
*\(^___^)/* 🦒
@developandplay2 жыл бұрын
So happy you are back and working on stuff that I'm also interested in!
@CNLohr2 жыл бұрын
It may only be for a bit but I'm gonna try to make it longer!
@ioinfinity Жыл бұрын
*\(^___^)/* 🐒
@nethoncho2 жыл бұрын
This has helped me in planning my discrete TTL risc-v cpu. Thanks for posting
@CNLohr2 жыл бұрын
Excellent! If I find any bugs I'll do my best to keep updating the template. Someone else already used my emulator as a template to write a RISC-V emulator in squirrel.
@ioinfinity Жыл бұрын
*\(^___^)/* 🐑
@Maxjoker982 жыл бұрын
Great video, as always. And I know that the ESP32 isn't the only place this could be useful, but you can absolutely boot noMMU Linux natively on an ESP32 with external PSRAM! I've got a kernel+buildroot setup that boots successfully in QEMU!
@jesset25502 жыл бұрын
Esp32 cannot use the psram as rwx it can only rw or rx from the ram it's a limitation of the hardware.
@Maxjoker982 жыл бұрын
@@jesset2550 While that's technically true, a) that does not mean it can't run Linux b) ESP32-S3, the newest ESP32, actually can just map 32MB of external RAM on *both* data and instruction bus. It works in QEMU already, I'm almost confident that I can get this to work on real hardware when I finally get a real ESP32 with PSRAM in my hands.
@browaruspierogus21822 жыл бұрын
@@Maxjoker98 ESP32-S3 is not RiscV and has closed ISA protected by Xtensa. Esp is slowly replaced by chips like K210 or latest M1s that are superior and cheaper and much better. Espressif should make 64bit dual core riscv to make it easier for people but they care about money more
@Maxjoker982 жыл бұрын
@@browaruspierogus2182 I never claimed the ESP32 S3 is RISC-V. Also the Xtensa ISA is well documented(You probably mean they should freely license it and their designs based on it). But I think what they should do is make the tiniest noMMU Linux capable SoC they can make, with Wifi and Bluetooth. I think there would be a market for that. And they already make the S3, which is capable of running Linux - I would love an ESP with RISC-V and PSRAM support, but that doesn't exist yet(It wouldn't have to be such a large and complex SoC as the K210, which is way more expensive).
@browaruspierogus21822 жыл бұрын
@@Maxjoker98 you probably didn't read posts on esp32 forum how many problems S3 has with managing f.ex LCD and Wifi/BT at same time. And how clunky and bas is psram. The design is really bad and they need to come up with better design
@wi8shad0w2 жыл бұрын
Thumbs up for putting it together .. 👍🏼👍🏼
@pedrorocha62032 жыл бұрын
Nice one! Thanks for sharing, there's a lot of cool stuff to learn from this... cheers!
@CNLohr2 жыл бұрын
This RISC-V emulator is like the gift that keeps giving. I just made two more videos on it, you should check my channel.
@ioinfinity Жыл бұрын
*\(^___^)/* :😺
@jamesdoesthings10962 жыл бұрын
Yay new upload!
@maxime22000b2 жыл бұрын
I learnt a lot with this video, thanks for sharing. Hope you'll continue this project and make other cool stuff with it !
@CNLohr2 жыл бұрын
I'm gonna be making at least one more, so be sure you're subbed!
@maxime22000b2 жыл бұрын
@@CNLohr I am, for quite a long time already ;)
@atypicalambience34872 жыл бұрын
It's funny how many times I have rediscovered your channel learning about unrelated interesting things.
@CNLohr2 жыл бұрын
I like finding out lots of unrelated interesting things!
@iuri.castro2 жыл бұрын
Great project! love your videos, I hope you have more time to do them next year!
@CNLohr2 жыл бұрын
We will see. I may or may not.
@ioinfinity Жыл бұрын
*\(^___^)/* 🐒
@Anon.G2 жыл бұрын
Great video
@JohnLauerGplus2 жыл бұрын
Dude, nice work on this!
@CNLohr2 жыл бұрын
Thanks!
@مقاطعمترجمة-ش8ث2 жыл бұрын
Nice to see come back with such beautiful way.
@CNLohr2 жыл бұрын
Thanks. I "want" to keep making videos. It's just really hard to keep up the momentum.
@0x1EGEN2 жыл бұрын
Haha this is brilliant!
@qbqbqdbq2 жыл бұрын
solid work
@vreascul2 жыл бұрын
maybe you don't want to put a red line at the bottom of the thumbnail as some people may think that they already watched the video
@RagbagMcShag2 жыл бұрын
100%
@vreascul2 жыл бұрын
also, great work!
@CNLohr2 жыл бұрын
Osnap.
@Weaseldog2001 Жыл бұрын
This is cool. I'm working on a very similar project for a RISC-V emulator, intended to be run as a sandbox inside of other applications. It'll be my second go at writing an emulated CPU. My first one used a made up machine instruction set, and I programmed in machine code by hand. When I paid attention to the RISC-V, I saw that my project was similar in may ways. In this second attempt, I am focused minimizing resources and and maximizing speed. After looking into other emulator projects, including yours, I see that the footprint is likely to be smaller than I anticipated.
@CNLohr10 ай бұрын
You might want to join my Discord, there's other RISC-Vers there. You can ping me at `cnlohr` on Discord.
@MarquisDeSang2 жыл бұрын
Now try to implement prediction branching (it would probably slow down everything). Impressive stuff. Making a Risc-V emulator is something, maiking it actually run an OS is a different thing. I have the Neza Sipeed Risc-V SBC with Debian, Risc-V is the only possible future for everything. It is so well designed and their ABI makes everything faster because we know what registers to use.
@CNLohr2 жыл бұрын
It almost certainly would slow things down, because there's already going to be branch prediction on the emulating hardware. Making that more sophisticated will just add abstraction overhead.
@MarquisDeSang2 жыл бұрын
@@CNLohr It would probably still run faster than WASM
@tablettablete186 Жыл бұрын
@@MarquisDeSang lol
@ioinfinity Жыл бұрын
*\(^___^)/* 🐕
@ioinfinity Жыл бұрын
*\(^___^)/* 🦒
@filipszkandera82672 жыл бұрын
That is so awesome! This really encourages me to try to implement Linux on my RV32 system as well! (I'm not sure Its doable, but we'll see :))
@CNLohr2 жыл бұрын
yess
@紺野-純子2 жыл бұрын
actually insane
@iamvfx2 жыл бұрын
Nicely done!
@CNLohr2 жыл бұрын
Thanks!
@guatagel24542 жыл бұрын
Hi! Good to see you!
@blablamannetje Жыл бұрын
Amazing! Thank you.
@dakshinatharindu7422 Жыл бұрын
Great work! Thanks for sharing
@CNLohr10 ай бұрын
Thanks for watching
@joedoe36882 жыл бұрын
that was impressive!
@CNLohr2 жыл бұрын
Thanks.
@raguaviva2 жыл бұрын
we missed you!
@CNLohr2 жыл бұрын
I know it's just so hard to make time to make these videos.
@JohnMitchellCalif2 жыл бұрын
wow, super interesting!
@killiangrieg Жыл бұрын
This is most impressive.
@justanormalperson2 жыл бұрын
that's cool
@_LocalerАй бұрын
Great video. I want to also write an emulator for learning
@CNLohrАй бұрын
You should! Hopefully I've pointed out a reasonable way forward!
@lior_haddad2 жыл бұрын
That's really cool!
@CNLohr2 жыл бұрын
Thanks
@SlyEcho2 жыл бұрын
I tried to do a similar project, what helped me to get the decoding right was to print out the assembly and then it was pretty apparent if some number was wrong in comparison. 5:25 can you replace the ninja requirement with samurai? That one is pure C and Make. 14:04 xxd -e can show in little endian
@CNLohr2 жыл бұрын
14:04 - I didn't know that. And - I can't update the way buildroot builds. At this point, I've just removed qemu from the build tree.
@BryanChance2 жыл бұрын
Thanks for this video. I’m trying to learn to do something like this
@CNLohr2 жыл бұрын
I think you'll like my channel then! This kinda stuff is my jam.
@BrianG61UK2 жыл бұрын
Is the slowdown after initial stages of boot because I/O changes from polled to interrupt driven?
@CNLohr2 жыл бұрын
I believe so. Or more specifically, that the Kernel appears to force a context switch because it assumes there "should" be no more room left in the output buffer even though there is.
@lowercasebtwalso2 жыл бұрын
could you port this to webassembly then run Linux in the browser
@CNLohr2 жыл бұрын
Someone already made a better RV32 emulator that runs in-browser. bellard.org/tinyemu/
@SuperIva-DIY-RUS2 жыл бұрын
Wow! I wonder is it possible to run beowoolf cluster on blades based on risc-v (allwiner d1 for example)? And teach it to work with 10BASE-T for example? That is the case I would invest..
@CNLohr2 жыл бұрын
probably!
@bennguyen13132 жыл бұрын
In case anyone is interested, there's a good video where George Hotz opens the spec, and starts writing a little RISC-V core in Python and in Verilog! BTW, with so many different flavors of Risc-V chip, each selecting the ISA options it wants.. won't the performance between chips be different, depending on the silicon technology, and how it implements those instructions?
@CNLohr2 жыл бұрын
It absolutely will depend vastly. You could have 20MHz cores or 2GHz cores.
@BrightBlueJim Жыл бұрын
@@CNLohr Just as you can with ARM.
@LogicEu2 жыл бұрын
Wow!
@oglothenerd Жыл бұрын
Time for me to rewrite it in Rust!
@awuuwa2 жыл бұрын
impressive
@CNLohr2 жыл бұрын
Thank you!
@prozacgodretro2 жыл бұрын
So... a question... can a No-MMU version of linux work on a 386 in something like an unreal mode? I've been thinking about this for the past couple days as I also became aware of the no-mmu kernel stuff.
@CNLohr2 жыл бұрын
As it stands, there's a little extra code that needs to be written per-architecture and there are still some unusual restrictions. But, the underlying answer is now "yes."
@proxy1035 Жыл бұрын
i'm sorry if you mentioned it in the video but i didn't notice if you said that your Emulator follows the Unprivileged or Privileged Spec for RISC-V. having Linux run without an MMU is already pretty dope, but it would be even more amazing if it could also run on a CPU without seperate privilege levels (like Unprivileged RISC-V) and just enough CSR's to implement a few interrupts.
@alexv18412 жыл бұрын
thans for sharing! terminal font name please
@CNLohr2 жыл бұрын
Mentioned in my other video description "AudioLink Mono" -- It's available on the VRChat AudioLink Discord
@der.Schtefan Жыл бұрын
Have you considered using ATDD (acceptance test driven design), especially with Cucumber, to test the specs of your CPU, before you implement it or run Linux on it? Or was the goal to make the source as small as possible, including "no unit test"? I think I would start getting nightmares designing a CPU emulation software without the ATDD for each operation.
@kotcraftchannelukraine6118 Жыл бұрын
But what problem with adding MMU features to the emulator?
@CNLohr10 ай бұрын
Nope. It adds code. I need the smallest emulator that can boot Linux
@fluffycritter2 жыл бұрын
MMUless Linux isn't anything new; 15 years ago a lot of embedded systems ran µClinux (aka uClinux), which was a fork of Linux specifically to not require an MMU. Really cool to see the idea alive and well, even if under a different project. And of course, really neat to see just how little code is actually necessary for RISC-V emulation (which isn't terribly surprising given the whole point to RISC-V).
@CNLohr2 жыл бұрын
This is mainline. Not a fork. That's what makes it so cool.
@fluffycritter2 жыл бұрын
@@CNLohr Yeah, apparently uClinux got merged in quite some time ago! So it's neat that it's still working.
@erikwg3814 Жыл бұрын
"It's like an embeddable scripting language, except you can compile to it with gcc" That is indeed one way describe an entire RISC-V emulator xD
@CNLohr Жыл бұрын
I'm glad it was technically accurate.
@BrightBlueJim Жыл бұрын
Scripting languages are all virtual machines. However, the point of most scripting languages is to avoid some of the difficulties encountered with compiled languages. So what has been achieved? You can now write in C what you could have written in Python? Umm...
@illegalcoding2 жыл бұрын
Hey! Great video! I'm just wondering what font you use for your terminal and text editor? It looks great!
@CNLohr2 жыл бұрын
audiolink.dev/
@Kuratius Жыл бұрын
Would this be adaptable for a pi pico or does it require a lot of ram? I mean the linux kernel, less the emulator.
@CNLohr Жыл бұрын
There already is someone who's adapted it for the pico. It's called pico-rv32ima
@oglothenerd5 ай бұрын
Linux can run on something without an MMU!?
@CNLohr5 ай бұрын
Abso-lutely!
@PaulTaylor12 жыл бұрын
I love that font on your terminal emulator, what's it called please?
@CNLohr2 жыл бұрын
It's in the description. audiolink.dev
@teddyjuma20602 жыл бұрын
Whats your terminal font?
@CNLohr2 жыл бұрын
AudioLink Mono. It's by Llelloo in the VRChat AudioLink Discord Server
@alexhajnal1072 жыл бұрын
@@CNLohr Is that available for download anywhere?
@justgook2 жыл бұрын
+1 really interested
@CNLohr2 жыл бұрын
@@justgook audiolink.dev/
@justgook2 жыл бұрын
@@CNLohr thanks
@belesiu2 жыл бұрын
Charles! Nice Good to see you. Nice video. Still at the place we worked together at a few years ago?
@CNLohr2 жыл бұрын
Still hanging on. Though I feel a little like "hang In there" from S08E11 of the Simpsons.
@belesiu2 жыл бұрын
@@CNLohr Mob war or free pretzels?
@bart.grantham2 жыл бұрын
Where can one find "AudioLink Mono"?
@CNLohr2 жыл бұрын
audiolink.dev/
@l3p32 жыл бұрын
I feel like we have the same weird special interests just again. Running linux on $1 mcu is what I dream of for a long time. Someone seen my nc10 netbook from 2009 that I upgraded with usb 3.0? xD
@CNLohr2 жыл бұрын
I think there's a chance!
@BrightBlueJim Жыл бұрын
The magic is that the $1 MCUs are so CAPABLE. I remember not too long ago, when people doing stunts like booting Linux on an 8-bit machine ... in about an hour.
@omercelebi20122 жыл бұрын
I did not understand any point of this but watched. I know just Python and want to be familiar with C or Assembly. I would like to get tips where can I start RISC-V and do some simple projects.
@CNLohr Жыл бұрын
I am not sure if I have the best answer. You usually learn C before doing embedded.
@thechadbuddha2 жыл бұрын
funfact: opencomputers2 a minecraftmod has risc V emulation
@browaruspierogus21822 жыл бұрын
Kendryte K210 is great but newer 3-core riscV mcu is out too - M1s
@CNLohr2 жыл бұрын
Sadly RV64, so less interesting for my purposes.
@browaruspierogus21822 жыл бұрын
@@CNLohr guess you don't read specs at all...
@x7mdNet2 жыл бұрын
We need to compile it to WebAssembly 😱
@CNLohr2 жыл бұрын
It is painful that I'm not adding goto's to this code for this very reason.
@x7mdNet2 жыл бұрын
@@CNLohr :(
@LekKit_2 жыл бұрын
RVVM actually works with this, but perf is abyssmal ;D, and there is a way to do RISC-V->WASM JIT Sadly YT removes links to test page
@fifthperson97772 жыл бұрын
Does this mean i can run yolov5 on maixduino??
@CNLohr2 жыл бұрын
y not
@kamillatocha2 жыл бұрын
so did you made it run in VRchat ?
@CNLohr2 жыл бұрын
Not... yet.
@BrightBlueJim Жыл бұрын
At first I thought, why would you want to emulate a microcontroller, on a microcontroller? But then I slowly started to realize, that it's all a matter of priorities. If you need more memory than your microcontroller has, then one option is to do swapping to an external device, to allow you to use more memory than you have, at the cost of a big reduction in performance. And sometimes it's worth the cost to be able to do things you otherwise couldn't. I say "external device", because I can just see people thinking to accelerate things by swapping to the on-chip Flash memory, and thereby wearing out their microcontrollers. I think Tesla had a problem like this. But if you have socketed Flash memory, in the form of SD cards or whatever the latest socketed format is, then what gets worn out is something that's replaceable. I worry about this a little on my laptop, since it runs a devil-may-care OS that swaps to a solid state drive that is a bit of a pain to replace. But then, by the time it wears that out, I'll be able (probably) to replace it with a bigger, faster SSD.
@CNLohr Жыл бұрын
Absolutely! There's a lot of weird reasons why it makes sense to virtualize your functionality. It's really nice to do with RISC-V because there's such good tooling and compilers to minimize the perf hit and frustration.
@sorin.n2 жыл бұрын
Yeah, but can it run Doom? 😅 Amazing work! 👍
@sellicott2 жыл бұрын
He just posted a screenshot of it running Doom in the Discord last night.
@sorin.n2 жыл бұрын
@@sellicott I was just jocking but that's so cool!
@CNLohr2 жыл бұрын
Check out my video I just posted! "But can it run doom?"
@BrutalStrike22 жыл бұрын
Got 10 IQ by just watching this video
@CNLohr2 жыл бұрын
It'll fade, but I'll try to keep making videos to help keep the IQ up!
@vincei42522 жыл бұрын
Dude, you need a microphone pop-filter. Otherwise awesome stuff!
@CNLohr2 жыл бұрын
I have one - it's just a few parts I re-recorded I didn't have it.
@vincei42522 жыл бұрын
@@CNLohr Ok, no worries. I noticed the audio got much better. I'm quite impressed with this project and I'm soaking up as much of it as possible. Build failed in subsystem for windows so I'll spin up a Linux VM to have a play. Thanks!
@CNLohr2 жыл бұрын
@@vincei4252 let me know how it goes. I miiight try building it in WSL myself.
@CNLohr2 жыл бұрын
@@vincei4252 Also see my note about needing to fix your paths for WSL.
@vincei42522 жыл бұрын
@@CNLohr ugh. KZbin. Sorry, I just saw your response. I wasn't notified. I was able to get everything working in a VM all the way to the command prompt. Superb stuff. Got sidelined on other things but EEVBlogs video about 10 cent RISC-V microcontrollers reminded me to come back here.
@replikvltyoutube37279 ай бұрын
this could be useful to make DSLinux 2.0
@CNLohr9 ай бұрын
There are a ton of applications, and it's small and easy to use so give it a go!
@RooMan932 жыл бұрын
Maybe the og PSP can run Linux now
@CNLohr2 жыл бұрын
Looks like it should have no issues.
@sellicott2 жыл бұрын
First!
@Jkauppa2 жыл бұрын
emulate the mmu inside the operating system
@Jkauppa2 жыл бұрын
its just a memory access interface adapter
@Jkauppa2 жыл бұрын
any law rule based will drain your iq if you rely on it
@Jkauppa2 жыл бұрын
your life is death
@Jkauppa2 жыл бұрын
what you praise shows what you believe in
@CNLohr2 жыл бұрын
It would be toooo sloowwwww
@paulk3142 жыл бұрын
This is awesome! I've been working on some similar hobby projects but nothing nearly as ambitious as trying to run Linux. I would not have imagined it could be run without an MMU (aside from in the "universal Turing machine" sense). I'm working on a simulator, assembler, and RTL implementation for FPGA. I want to get a basic RISC-V computer working on FPGA and then write a simple kernel for it. Now that I've seen this video, I'm more optimistic that I could at some point get Linux running on there, which would be amazing!
@be-tech17412 жыл бұрын
Very interesting..
@CNLohr2 жыл бұрын
Do ett. You could also try to make things _even more stripped down_ and use an emulator as a test bed for the features you intend to implement.
@kreuner112 жыл бұрын
Ninja doesn't need Cmake, Cmake wants wither ninja or regular make
@CNLohr2 жыл бұрын
It's how Python is configured to compile.
@kreuner112 жыл бұрын
@@CNLohr yeah but idk if you got it in the right order,
@gvl6102 жыл бұрын
Will port it to Arduino Uno
@CNLohr2 жыл бұрын
😬
@BrightBlueJim Жыл бұрын
Of course it will. It has SPI, so just rack up a whole bunch of PSRAM. Everything else is just software.
@GeorgeTsiros2 жыл бұрын
python because there weren't enough scripting languages already
@GeorgeTsiros2 жыл бұрын
line 227, system("") huh? that one of the common windows bullshitty undocumented stuff?
@CNLohr2 жыл бұрын
Absolutely. I explained it in my doom deep dive video I just uploaded.
@BadBoy65t6 ай бұрын
Now remake the entire video in english please 😂😂
@CNLohrАй бұрын
This was the best I Can do.
@SquidHominid2 жыл бұрын
Please invest in a pop filter. This video is VERY hard to listen to because of all of the plosives. Otherwise, amazing work! This is really cool and I look forward to seeing what you do next. :)
@waldolemmer2 жыл бұрын
Boo
@CNLohr2 жыл бұрын
Thanks! And I do have one, I just didn't use it for a few of the parts I had to re-record.
@soyitiel2 жыл бұрын
Linux in a shader go 🧮
@CNLohr2 жыл бұрын
Already been done. Just the question is can I do it better