-
Notifications
You must be signed in to change notification settings - Fork 120
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Discussion on possible code size reductions #108
Comments
This function code was used in some special cases a few years ago. Removing it is possible, but will break all existing user-written control functions. As we are working on an update for 4.2.x, we could announce this change for the next major version 4.3 (with the SDO client segmented transfer). I think we can assume it is a relict and can remove it to gain some resources. The breaking change will be: /*!< Control type function prototype (OLD) */
typedef CO_ERR (*CO_OBJ_CTRL_FUNC) (struct CO_OBJ_T *, struct CO_NODE_T *, uint16_t, uint32_t);
/* will be replaced by */
/*!< Reset type function prototype (NEW) */
typedef CO_ERR (*CO_OBJ_RESET_FUNC) (struct CO_OBJ_T *, struct CO_NODE_T *); |
Ctrl handler is also used by COTAsync but it's scope is limited to PDOs, so ctrl handler might still be needed. Please correct me if I'm wrong, but there are actually two ways that stack signals to reset offset:
Second option is nice and doesn't need any additional handler. What do you think? |
You are right, it is used in asynchronous PDOs, too. Summary:
On one hand: On the other hand: Will removing the arguments in the control function solve your code size issue? |
Removing just parameter saves 136 B of code in my firmware, so not much, but it something. I think I'll get better code size savings by reworking some other parts of the firmware. Thanks for looking into this! |
Can you share your current size and the size you want to achieve? Just to get a feeling on the challenge ;-) |
Current firmware size without modifications is 65474 B and 65336 B without parameter in ctrl handler. Code space is 16 B less than 64 kB. CANopen stack with dictionary and custom types takes more than half of that. I need a few kBs of space to implement remaining features. There are some reserves by using size optimization level in compiler and some minor things across my firmware, which should be enough. I was just looking for low hanging fruits, like offset management here. |
One idea may be to add a conditional compilation flag Note: this is not implemented right now and needs to be done. But I guess it is fairly easy to do. |
Thanks for reminding me. While block transfers are useful for speedy firmware updates, they are not essential. I can disable them as a last resort, if there won't be enough space. |
As far as I can see, there are only 2 functions, which set offsets and in all cases, it's set to 0. What is rationale behind this control? Is it remnant of the past or for some future functionality? Removing it would lower code size and simplify stack a bit. While this probably doesn't affect big MCUs much, it can be noticeable on smaller MCUs, like the one I'm working on (proprietary design).
The text was updated successfully, but these errors were encountered: