...
Expand | ||
---|---|---|
| ||
From the ./lib directory: cwassert.h, cwcrc16.c, cwcrc16.h, cwdll.c, cwdll.h, cwnwk.c, cwnwk.h, mjson.c, mjson.h, cwver.h From the ./_OpenKitchenEquipment_OKE directory: cwcmd.c, cwcmd.h, cwmsg.c, cwmsg.h Implementors should not modify any of these files. |
Expand | ||||
---|---|---|---|---|
| ||||
From either the ./_OpenKitchenEquipment_OKE/ports/windows or ./_OpenKitchenEquipment_OKE/ports/linux directory copy the following files: cwport.c, cwport.h, cwmsgsel.h, and optionally strlcpy.c if your platform does not natively support strlcpy(). main.c is example startup code. Embedded platforms will start their port using either the Windows or Linux port as a baseline. Carefully read the integration instructions contained in cwport.c and cwport.h and modify either the Windows or Linux specific implementation Begin embedded controller integration by commenting out much of the functions in these two files until the code compiles. Then modify to work on your controller.
For the initial port, it is recommended to set CW_PORT_INVALID_OKM_HARD_ERROR to 1 and CW_PORT_IS_FILE_SUPPORT_ENABLED to 0 in cwport.h. This will minimize the number of functions that must be implemented to get the first port working.
It is strongly recommended that MJUnitTest() is run to verify that the JSON library is working correctly on the target platform. If you have previously ported the CWL successfully and are updating to the newer version of the CWL then merge your existing cwport.c and cwport.h files with the newer versions of those files. For cwport.c if the function signatures match it is generally safe to bring over your existing code without modification, however care should be taken to follow any new porting guidelines for those functions. For cwport.h make sure to bring over your port configuration settings and configure any new settings as appropriate for your system. |
Expand | ||
---|---|---|
| ||
Call CWPortInitTask(), and then from the main loop or dedicated task/thread periodically call CWPortRunTask(). Refer to ./_OpenKitchenEquipment_OKE/ports/windows/main.c for an example of how to initialize and call the ConnectWare Library from your main() function. See CWL Task for a detailed explanation of how to properly invoke CWPortInitTask() and CWPortRunTask(). |
Expand | ||
---|---|---|
| ||
Connect the controller to a serial port on a Windows PC. Run the cwm.exe and okc.exe programs included with the CWL sources. The simulated CWM and OKC allow you to test the port running on the controller. See https://sitesage.atlassian.net/wiki/x/FYBWHQ for instructions on using the simulators. |
Expand | ||
---|---|---|
| ||
The simulated CWM and OKC will make it much easier to debug the CWL port than connecting to the real system.Review the implementation sanity checklist included towards the end of this document.Validate the port is fully functional using the https://sitesage.atlassian.net/wiki/x/GgBXHQ After debugging ask for a code review of your cwport.c/h files before moving to the next step. |
Our goal is that the CWL compiles cleanly without warnings or errors on all toolchains. If any warnings or errors are encountered that require changes to core CWL files, then please report it to the maintainers.