Keil uVision
Here we will explain a bit about the library file, and how to embed this into your Keil uVision Project
Setting up The Keil Project
In a Keil Project, you will likely need to do the following steps for all Targets (release and debug, usually) in a given project. The example project shown below is from the Nordic Thingy SDK. Select Project → Options for Target…
Adding the Library (libsensiml.a)
Add a group to your project/target, to keep your project organized.
data:image/s3,"s3://crabby-images/3dc17/3dc174867fe78039c003ac8077294f99e1f885f6" alt="../../_images/keil-add-group.png"
Rename the group “SensiML” or anything of your choosing. Then, right click this new group and then “Add Existing Files to Group”
data:image/s3,"s3://crabby-images/1bcd2/1bcd26e58c9e2d96b37697be2389f57b516602f7" alt="../../_images/keil-add-library-to-group.png"
Select “Asm Source file” from the drop down, and navigate to where you placed the sensiml folder:
data:image/s3,"s3://crabby-images/fb55d/fb55d0cd826033965459f461c7e7d6f99c3767f4" alt="../../_images/keil-asm-source.png"
Choose libsensiml.a, and “Add”
Right click libsensiml.a in the Project panel, and choose options:
data:image/s3,"s3://crabby-images/665c7/665c760009720076b7621581a6cbb6b43945cfa7" alt="../../_images/keil-library-options.png"
Change the File Type to Library File:
data:image/s3,"s3://crabby-images/cf6c8/cf6c8ffbb4f742faaf9e06b0100a6b266b4df775" alt="../../_images/keil-change-to-lib-file.png"
You can then add existing files (the organization of the group is up to you) for the SensiML group, to add the header files:
data:image/s3,"s3://crabby-images/645f3/645f35bab161021b730304f41bb69779dbe8095c" alt="../../_images/keil-add-headers.png"
Adding Include Directories
Click on C/C++ to modify your include paths with the highlighted button:
data:image/s3,"s3://crabby-images/eb178/eb17866146d99fb95361cb09aa669071f0aa36aa" alt="../../_images/keil-add-include-dir.png"
Add a new include path. Navigate to the place you copied the sensiml or libsensiml directory to, and select the inc folder.
data:image/s3,"s3://crabby-images/ca253/ca2537e85876e58cc20137bcf35417078b5bf87b" alt="../../_images/keil-add-include-dir-2.png"
Important
Because we compile with GCC in the cloud, it produces character pointers with 32-bit width. Arm compiler default is 16-bit width. This will make your program fail to build. You will need to ensure that the compiler flag --wchar32t
is set in the Misc. Controls section of C/C++:
data:image/s3,"s3://crabby-images/565cf/565cf614f977c91ca14c74656c865d2d6d44f35f" alt="../../_images/keil-wchar32.png"
Library Integration
Now you are ready to integrate the Knowledge Pack library with your code. Most modern linker applications will not link the library until you actually make a call to a function within the library. See more on how to do this at Building a Knowledge Pack Library