Annotate riscy059
This commit is contained in:
parent
2940f8df60
commit
2576897923
|
@ -0,0 +1,106 @@
|
||||||
|
[video member=miotatsu stream_platform=twitch project=riscy medium=research title="Playing with a Fedora chroot & Ion on the HiFive Unleashed" vod_platform=youtube id=AHH-KfjJn_s annotator=Miblo]
|
||||||
|
[0:13][Begin to recap and set the stage for the day][:speech]
|
||||||
|
[0:17][@riskyfive][\\o/]
|
||||||
|
[0:39][@riskyfive][Hmm, I can't see my own text]
|
||||||
|
[1:19][@riscyfive][Ah, any feedback on the podcast? Boring? Confusing?]
|
||||||
|
[4:28][Plug @riscyfive's podcast 'Why So Anemic'[ref
|
||||||
|
site="Twitter: @coredumppodcast"
|
||||||
|
page="Episode 1: Why So Anemic?"
|
||||||
|
url=https://twitter.com/coredumppodcast/status/985931647437672448]]
|
||||||
|
[4:42][@riskyfive][Well, I want(ed) to keep my mind open. If I had found out (or I later find out) that the OOP-style modeling was the best option then so be it. I just want to get at the truth, I don't have a camp]
|
||||||
|
[5:30][@riskyfive][People at DConf 2016 thought I was Italian, due to the way I talk]
|
||||||
|
[6:11][Determine to continue doing stuff with the HiFive Unleashed, [ref
|
||||||
|
site="SiFive Forums"
|
||||||
|
page="Is there a more complete system image for Unleashed board?"
|
||||||
|
url=https://forums.sifive.com/t/is-there-a-more-complete-system-image-for-unleashed-board/1146]]
|
||||||
|
[10:49][Explain the process of installing Fedora onto the HiFive Unleashed,[ref
|
||||||
|
site="Fedora Project Wiki"
|
||||||
|
page="Architectures/RISC-V"
|
||||||
|
url=https://fedoraproject.org/wiki/Architectures/RISC-V] noting the block size in Arch Linux's example dd invocation[ref
|
||||||
|
site="Arch Wiki"
|
||||||
|
page="USB flash installation media"
|
||||||
|
url=https://wiki.archlinux.org/index.php/USB_flash_installation_media#In_GNU.2FLinux]]
|
||||||
|
[15:42][@riskyfive][By the way, you probably don't have video on your RISC-V system. SiFive used an adapter FPGA board for their demo. I wanted to share with you and your viewers that you can buy the Nexys Video (the bigger one recommended for ~Bitwise) using an academic discount. I ordered one. We can then later collaborate to get HDMI output using one, or something like that. I can help you with that]
|
||||||
|
[17:02][Continue to explain the dd part of the installation process]
|
||||||
|
[17:44][@riskyfive][You can even add MP4 encoding in the FPGA itself. No need for OBS]
|
||||||
|
[18:38][Continue to explain the installation process]
|
||||||
|
[19:08][@riskyfive][You need more Patreons. I'll try to promote you[ref
|
||||||
|
site=Patreon
|
||||||
|
page="miotatsu is creating RISCY BUSINESS"
|
||||||
|
url=https://www.patreon.com/miotatsu][ref
|
||||||
|
site=Gumroad
|
||||||
|
page="RISCY BUSINESS: Programming a handmade tool-chain for RISC-V live on Twitch"
|
||||||
|
url=https://gumroad.com/riscy]]
|
||||||
|
[20:49][Finish up explaining the setup process, including building the Ion compiler from ~bitwise and having it run out of the box!]
|
||||||
|
[23:00][Don the antistatic wristband and plug in the HiFive Unleashed][:admin]
|
||||||
|
[24:03][@riskyfive][Where are you plugging the band?]
|
||||||
|
[25:03][@riskyfive][The "duct tape" method. Good engineering]
|
||||||
|
[25:23][Read 5.3. Knobs on the HiFive Unleashed[ref
|
||||||
|
site="SiFive Developers"
|
||||||
|
page="HiFive Unleashed Getting Started Guide"
|
||||||
|
url=https://www.sifive.com/documentation/boards/hifive-unleashed/hifive-unleashed-getting-started-guide/]]
|
||||||
|
[27:02][@riskyfive][I've worked with $5K boards at Siemens without grounding and they never exhibited problems. After that I never cared too much]
|
||||||
|
[28:47][@riskyfive][That actually was very surprising because I kept getting shocked due to the static discharges at that laboratory (when touching the server racks). But the hardware itself never complained]
|
||||||
|
[30:25][@riskyfive][No, there was a ground. But we were busy and lazy! Maybe that was the trick: I kept discharging myself unintentionally!]
|
||||||
|
[30:42][Plug in and power up the board][:admin]
|
||||||
|
[31:53][@riskyfive][Yeah, I pretty much only have grounded plugs in the kitchen]
|
||||||
|
[32:18][Connect to the HiFive Unleashed and setup the environment][:admin]
|
||||||
|
[36:45][@riskyfive][It seems the cool kids use tmux these days]
|
||||||
|
[37:09][Delete our test files related to ion][:admin]
|
||||||
|
[40:01][@riskyfive][Try: $ shopt | grep checkwinsize]
|
||||||
|
[41:05][Compile ion, :run generate_test.py, show the resulting Ion code in test3.ion, run ion on that file to produce test3.c]
|
||||||
|
[43:54][Point out that qemu[ref
|
||||||
|
site=QEMU
|
||||||
|
url=https://www.qemu.org/] may provide the closest means to follow along, without having to invest in a HiFive Unleashed][:speech]
|
||||||
|
[45:30][Try to :run ion on test2.ion and then gcc on the resulting test2.c file]
|
||||||
|
[46:54][Try to :run ion on test1.ion and then gcc on the resulting test1.c file, to see printouts and input totally working][:"input handling"]
|
||||||
|
[48:39][Read through test1.ion]
|
||||||
|
[51:45][:Run test1 to provide the first demo of Ion code compiled to and running on RISC-V]
|
||||||
|
[52:50][Note @Miblo's thought to use readelf while he wrote annotations for ~Bitwise][:speech]
|
||||||
|
[55:12][:Run objdump on test2]
|
||||||
|
[55:44][Determine to run objdump on hello][:speech]
|
||||||
|
[56:51][@riskyfive][I use readelf all the time for my empire RISC-V port]
|
||||||
|
[57:03][Continue to figure out how to unfreeze the screen][:admin]
|
||||||
|
[57:57][@riskyfive][Ctrl-q?]
|
||||||
|
[58:21][Note the annoyance of the XOFF ASCII character and screen's default keybinding for it][:rant]
|
||||||
|
[59:39][@riskyfive][Yeah, very annoying. Arguably it's just it not ignoring the ASCII characters (XON / XOFF) that you actually typed]
|
||||||
|
[1:00:30][Copy hello into the (Fedora) chroot environment][:admin]
|
||||||
|
[1:01:06][@riskyfive][Yeah, but when you type Ctrl-something it emits certain ASCII characters that are control characters, like stop transmitting (freeze)]
|
||||||
|
[1:03:35][:Run objdump on our elf64-littleriscv hello]
|
||||||
|
[1:04:50][Consider trying the hula RISC-V "Hello, world!" on our HiFive Unleashed[ref
|
||||||
|
site=GitHub
|
||||||
|
page="riscy-business / hula"
|
||||||
|
url=https://github.com/riscy-business/hula]]
|
||||||
|
[1:05:37][@riskyfive][That's just what the ASCII character 19 means: stop transmitting. And when you type Ctrl-s you type that character. The real question is, who thought it was a good idea to transmit control information in-band with the content. That is, if you cat a .txt file that contains that character you're screwed]
|
||||||
|
[1:07:14][@riskyfive][You see, it used to be that terminals had dedicated wires for control. But then $ happened]
|
||||||
|
[1:07:31][:Rant on screen having kept legacy baggage around]
|
||||||
|
[1:09:31][Continue to compare the objdump of hello with hula[ref
|
||||||
|
site=GitHub
|
||||||
|
page="riscy-business / hula"
|
||||||
|
url=https://github.com/riscy-business/hula]]
|
||||||
|
[1:10:02][@riskyfive][With dedicated wires you don't need in-band control characters]
|
||||||
|
[1:10:43][@riskyfive][No, there was a message missing in between]
|
||||||
|
[1:10:52][Compare hula's "write" code with the hello objdump]
|
||||||
|
[1:11:55][@riskyfive][The Ctrl-z was an example of how the shell has the same problem]
|
||||||
|
[1:13:11][Note that the hello objdump may not show scall]
|
||||||
|
[1:14:08][@riskyfive][I agree it's braindead. But just think this: the initial Ctrl-a just means that you want the sequence Ctrl-a q to pass as a Ctrl-q to the target process. It's not a list of Ctrl-a commands, it just a generic escape]
|
||||||
|
[1:14:34][@riskyfive][scall -> ecall]
|
||||||
|
[1:15:14][@riskyfive][It's the old name]
|
||||||
|
[1:15:16][Wonder if the objdump is not using system calls, and that it's a lot bigger than hula]
|
||||||
|
[1:16:19][@riskyfive][Notice: disassembly of XXX (not .text) section]
|
||||||
|
[1:16:42][Hunt for a7 in the objdump because that is where you put the syscall number in RISC-V]
|
||||||
|
[1:18:11][@riskyfive][You can do a readelf of the binary in your main system]
|
||||||
|
[1:18:27][Consult man readelf]
|
||||||
|
[1:19:25][:Run readelf -a hello]
|
||||||
|
[1:20:21][Read through the readelf of hello]
|
||||||
|
[1:21:40][@riskyfive][Maybe just try GDB with the binary?]
|
||||||
|
[1:22:13][Continue to read through the readelf of hello]
|
||||||
|
[1:22:31][@riskyfive][That's why you need the JTAG port]
|
||||||
|
[1:22:46][Return to the objdump of hello]
|
||||||
|
[1:23:42][@riskyfive][The system calls are probably wrapped in libc functions]
|
||||||
|
[1:23:55][Notice the mentions of "libc" in the hello objdump]
|
||||||
|
[1:24:49][@riskyfive][I think the ligc_start_main is just a red herring. Notice the offset is different between different __libc_start_main lines]
|
||||||
|
[1:25:58][Notice "libc_start_main" in the hello objdump]
|
||||||
|
[1:27:59][Consult the objdump of test1, to see that its symbols are correctly resolved]
|
||||||
|
[1:30:39][Call it a day][:speech]
|
||||||
|
[/video]
|
Loading…
Reference in New Issue