matrix_multiply
This readme is about the OpenAMP matrix_multiply demo. The matrix_multiply is about one processor generates two matrices, and send them to the one, and the other one calcuate the matrix multiplicaiton and return the result matrix.
For now, it implements Linux generates the matrices, and the baremetal calculate the matrix mulitplication and send back the result.
Compilation
Baremetal Compilation
Option WITH_MATRIX_MULTIPLY
is to control if the application will be built.
By default this option is ON
when WITH_APPS
is on.
Here is an example:
$ cmake ../open-amp -DCMAKE_TOOLCHAIN_FILE=zynq7_generic -DWITH_OBSOLETE=on -DWITH_APPS=ON
Linux Compilation
Linux Kernel Compilation
You will need to manually compile the following kernel modules with your Linux kernel (Please refer to Linux kernel documents for how to add kernel module):
- Your machine's remoteproc kernel driver
obsolete/system/linux/kernelspace/rpmsg_user_dev_driver
if you want to run the matrix_multiply app in Linux user space.obsolete/apps/matrix_multiply/system/linux/kernelspace/rpmsg_mat_mul_kern_app
if you want to run the matrix_multiply app in Linux kernel space.
Linux Userspace Compliation
- Compile
obsolete/apps/matrix_multiply/system/linux/userspace/mat_mul_demo
into your Linux OS. - If you are running generic(baremetal) system as remoteproc slave, and Linux as remoteproc master, please also add the built generic
matrix_multiply
executable to the firmware of your Linux OS.
Run the Demo
Load the Demo
After Linux boots,
- Load the machine remoteproc. If Linux runs as remoteproc master, you will need to pass the other processor's matrix_multiply binary as firmware arguement to the remoteproc module.
- If you run the Linux kernel application demo, load the
rpmsg_mat_mul_kern_app
module, you will see the kernel app will generate two matrices to the other processor, and output the result matrix returned by the other processor. - If you run the userspace application demo, load the
rpmsg_user_dev_driver
module. - If you run the userspace application demo
mat_mul_demo
, you will see the similar output on the console:
****************************************
Please enter command and press enter key
****************************************
1 - Generates random 6x6 matrices and transmits them to remote core over rpmsg
..
2 - Quit this application ..
CMD>
- Input
1
to run the matrix multiplication. - Input
2
to exit the application.
After you run the demo, you will need to unload the kernel modules.
Unload the Demo
- If you run the userspace application demo, unload the
rpmsg_user_dev_driver
module. - If you run the kernelspace application demo, unload the
rpmsg_mat_mul_kern_app
module. - Unload the machine remoteproc driver.