 0b97d0cb14
			
		
	
	
		0b97d0cb14
		
			
		
	
	
	
		
			
	
		
	
	zephyr: Enable WASI support for file system and sockets on zephyr (#3633) This work also implements the WASI support on Zephyr. * Added os_is_* methods for stdin/stdout/stderr. Fixed issues in os_renameat * Zephyr platform fixes for WASI sockets Addressed numerous of build warnings on Zephyr * Updated `os_writev` to use `fwrite` for STDOUT/STDERR * Temporarily reverted change to `writev` to work around an issue. * Fixes: fstat, fstatat, and unlink * Add initial support for directories in os_openat. Partial implementation — just avoids a hard fault. * Directory support WIP. readdir works but I think we have a memory leak somewhere * Fix: always use standard stream fds. Fix unlinkat and renameat. fd 0, 1, and 2 will always be supplied for standard streams. Unlinkat and renameat work exclusively based on supplied paths. * Fix: use macro for free() * Added a temporary workaround for issue identified in PR#4377 * Fixed reference to file descriptor and cleaned up dead/commented code. Note that some comments haven't been addressed and will be fixed in the further patches. Signed-off-by: Stephen Berard <stephen.berard@outlook.com> Co-authored-by: Lucas Abad <149054121+lucasAbadFr@users.noreply.github.com> Co-authored-by: Stephen Berard <srberard@users.noreply.github.com> Co-authored-by: Dan Kouba <dan@atym.io>
		
			
				
	
	
	
		
			5.4 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Socket sample
this sample demonstrates the use of WASI API to interact with sockets.
❗ Important: This sample was ported/adapted from the http_get zephyr sample. The original sample can be found here.
🛠️ Work in progress: The sample is functional but be aware that just a small part of WASI socket API was tested. Actual Zephyr APIs:
- socket creation =
zsock_socket- socket connection =
zsock_connect- socket emission =
zsock_sendto- socket reception =
zsock_recvfrom- socket destruction =
zsock_closeWith the sockets most API are in fact provided by the runtime instead of WASI because of the lack of socket support in WASI preview1.
Setup
- Connect a network cable to the board ethernet port.
- Configure the network interface on the host machine
Internet Protocol Version 4 (TCP/IPv4) Properties: IP Address: 192.0.2.10 Subnet Mask: 255.255.255.0 Default Gateway: 192.0.2.2
- Start a simple HTTP server on the host machine.
python3 -m http.server --bind 0.0.0.0
- Disable any firewall that may block the connection.
Configuration
To configure the server side IP address and port modify the following lines in the http_get.c file.
- 
The HTTP_HOSTandHTTP_PORTmacros define the server IP address and port./* HTTP server to connect to */ #define HTTP_HOST "192.0.2.10" /* Port to connect to, as string */ #define HTTP_PORT "8000" /* HTTP path to request */ #define HTTP_PATH "/" // ... #define REQUEST "GET " HTTP_PATH " HTTP/1.0\r\nHost: " HTTP_HOST "\r\n\r\n"📄 Notes: These macros are used to build the request string, but they are not used to instantiate the address structure. Because at one point we didn't want to use inet_ptonto convert the string to an address and it remained like this.
- 
The addrstructure is used to store the server address.addr.sin_port = htons(8000); addr.sin_addr.s_addr = htonl(0xC000020A); // hard coded IP address for 192.0.2.10
To configure the authorized IP address(es) modify the following lines in the main.c file. WAMR will only allow the IP addresses in the pool to connect to the server.
#define ADDRESS_POOL_SIZE 1
    const char *addr_pool[ADDRESS_POOL_SIZE] = {
        "192.0.2.10/24",
    };
Run Command
- 
Zephyr Build - 
Build: Replace nucleo_h743ziwith your board name and theWAMR_BUILD_TARGETinCMakeList.txtwith your target architecture.ZEPHYR_BASE=~/zephyrproject/zephyr \ WAMR_ROOT_DIR=~/wasm-micro-runtime \ WASI_SDK_PATH=~/wasi-sdk-21.0 \ WAMR_APP_FRAMEWORK_DIR=~/wamr-app-framework \ west build . -b nucleo_h563zi -p always⚠️ Warning: The flags ZEPHYR_BASE,WAMR_ROOT_DIR,WASI_SDK_PATH, andWAMR_APP_FRAMEWORK_DIRneed to be set otherwise the build will fail.
- 
Flash: ZEPHYR_BASE=~/zephyrproject/zephyr west flash
- 
Monitor: Use a serial link to monitor the output. Personally, I use minicom. minicom -D /dev/ttyACM0
- 
Debug: Curently investigating. 
 
- 
- 
WebAssembly Module ❗ Important: I used wasi-sdk 21 to compile the module. I still haven't tried the module with the new wasi-sdk 22. - Compile a static lib: in the wasm-appsfolder.- Compile the an object:
 ~/wasi-sdk-21.0/bin/clang --sysroot=/home/user/wasi-sdk-21.0/share/wasi-sysroot -Iinc/ -c inc/wasi_socket_ext.c -o inc/wasi_socket_ext.o- Create a static lib:
 ~/wasi-sdk-21.0/bin/llvm-ar rcs inc/libwasi_socket_ext.a inc/wasi_socket_ext.o
- Compile: in the wasm-appsfolder.~/wasi-sdk-21.0/bin/clang --sysroot=/home/user/wasi-sdk-21.0/share/wasi-sysroot -Iinc/ -nodefaultlibs -o http_get.wasm http_get.c -lc -Linc/ -lwasi_socket_ext -z stack-size=8192 -Wl,--initial-memory=65536 -Wl,--export=__heap_base -Wl,--export=__data_end -Wl,--allow-undefined
- generate a C header: Use xxdor other tool, I also put simple python script. At application rootsimple-http/.
 Be free to modify the script to fit your needs.python3 to_c_header.py
 
- Compile a static lib: in the 
Output
The output should be similar to the following:
*** Booting Zephyr OS build v3.6.0-4305-g2ec8f442a505 ***
[00:00:00.061,000] <inf> net_config: Initializing network
[00:00:00.067,000] <inf> net_config: Waiting interface 1 (0x2000a910) to be up...
[00:00:03.158,000] <inf> phy_mii: PHY (0) Link speed 100 Mb, full duplex
[00:00:03.288,000] <inf> net_config: Interface 1 (0x2000a910) coming up
[00:00:03.295,000] <inf> net_config: IPv4 address: 192.0.2.1
global heap size: 131072
Wasm file size: 36351
main found
[wasm-mod] Preparing HTTP GET request for http://192.0.2.10:8000/
[wasm-mod] sock = 3
[wasm-mod] connect rc = 0
[wasm-mod] send rc = 36
[wasm-mod] Response:
HTTP/1.0 200 OK
Server: SimpleHTTP/0.6 Python/3.10.10
Date: Fri, 14 Jun 2024 07:26:56 GMT
Content-type: text/html; charset=utf-8
Content-Length: 2821
# Skip the HTML content
[wasm-mod] len = 0 break
[wasm-mod] Connection closed
main executed
wasi exit code: 0
elapsed: 405ms