-
Notifications
You must be signed in to change notification settings - Fork 24
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
adding timer3 functions as servo.* because we need to control bots #142
Conversation
The reason I originally used timer was to have a more general timer3 https://www.pjrc.com/teensy/td_libs_Servo.html On Wed, Jun 25, 2014 at 7:22 AM, Ryan Day [email protected] wrote:
|
thanks! ill take a look. |
I have some concerns about this particular item. I believe that all of this code is going to be compiled into the system whether you use it or not. That might preclude other uses of timer 3 by other code. Also do you really need this code in order to operate a servo? I have connected servos to just about any PWM pin and use the standard Arduino Servo library without having to directly manipulate any hardware registers or using any interrupt service routines. Especially troublesome is the definition of a "ISR (…) {…}" routine. I had a similar routine in my IRLib library for infrared receiving, decoding, and sending. The ISR routine has to be globally defined. Users were complaining that if they were not using a portion of my library that required the ISR, it was conflicting with their use of an ISR. I had to put in a #define and an #ifdef… #endif around the routine to allow people to disable it if they wanted to. I've got no problem if this was a separate library that would encapsulate the timer 3 and servo functions that you have included. And have it customized for Pinoccio as you have done. But I don't think it should be part of the built in infrastructure. |
Thanks this is exactly the feedback I needed.
|
There's currently no infrastructure for dynamically loading code like this, and it seems that creating it would be very much non-trivial. It could of course be something that's separately enable-able at compiletime (by (not) including a library from the main sketch), which might be what you mean? I think an easier solution would be to mark the ISR as a weak function, allowing it to be overridden by a strong (non-weak) function in another part of the code. |
Yes this is exactly what I'm talking about. The functionality that it provides is not something that the average user is going to meet. You would only need it for a specific application and including it for everyone is just code bloat. But having it as a separate library that could be compiled in as needed is a better idea. I realize you can't dynamically load it on demand. But you can choose to include or not include the library and a custom sketch. For example I've got a custom sketch that wraps some of my infrared library into a bitlash/Scout script command called "ir.send(protocol, data, bits)". But unless you have a particular application that needs to send IR data that really doesn't need to be part of the overall Pinoccio firmware. Similarly unless I want to use my Pinoccio to control servos or otherwise manipulate TIMER 3 then I don't think it should be part of the built in infrastructure. Presumably at some point we would have a motor shield backpack and then I would think you would want to always include such a library anytime you are compiling a sketch for that particular backpack. But as a general purpose feature of Scout script I don't think enough people would use it to make it worthwhile. Just my opinion. |
As for code bloat - including it in the generic Bootstrap seems ok to me, at least until we reach the limits of our Flash space. People who use the compiled Bootstrap firmware aren't going to use the space for anything else. For people compiling a custom sketch, it makes sense to allow enabling / disabling code. However, this same goes for other stuff - you'd want to disable lead scout code as well for example. So I think this is a separate issue, that shouldn't block merging this pullrequest (see #148). As for the naming of these functions - I really don't like servo here, since it implies special servo support which simply isn't true. If we want to make people clear that they can use timer3 for servo's, then we should solve that with documentation - not innacurate naming. |
I can change the names back. You make good points. We discussed this a
|
I don't care what it's called I still think it should be a standalone library that you have the option to include or not include rather than having to edit some #define to disable. Actually the same thing goes for lead scout versus field scout. The lead scout specific code should all be in one library that gets included only when compiling sketches for leads Scouts. As far as the other comment about reaching the limits of flash memory, we need to think of this in terms of the Pinocchio core code being the operating system. Would anyone have bought Windows or OS X if the operating system had the attitude of "we will let the code grow until we reach the limits of memory". At some point you have to leave room for the application programs. The bottom line is this is not a feature that many people are going to use and so it must be extremely easy to include or not include. The easiest way to do that is to either #include <timer3.h> or not. |
we have been working with people where this is a very important feature to have out of box otherwise this wouldn't have been opened. the default hex we flash should include more things than we have in "core" so maybe we work on the bundling process.. more to think about =) |
If there was no way to actually install extra programs to make use of that extra memory (like currently with Pinoccio, if you use the precompiled bootstrap), then I don't think anyone really cared how much memory the operating system uses. Do you care how much flash space the firmware of your TV, wireless router, etc. takes (provided you can't install apps or more of that stuff)?
I agree on making it optional and I agree that having a separate library is probably the best approach (at least for timer3). However, this is really a separate issue that I'd like to solve later - get things working first. In any case, let's continue this discussion in #148 about how to approach making things optional. |
I'm going to close this since the code was merged into modules and will be showing up there again soon :) |
after quite a bit of user research we have decided to include timer3 functions as servo.* in master