4 Replies Latest reply on Feb 16, 2013 7:54 PM by userc_43661

    interrup high speed

       good afternoon


      My application is decoding a serial data frame, it has a frequency of 1MHz. I need to generate an interrupt whenever there is a rising edge and a falling edge (1MHz). I have read the reference manual, also AN54460, and works by placing the interruption to digital input pin to a frequency of 10kHz. If the digital input signal is above this interruption of 10Khz not work. Theoretically interruption should not depend on the frequency, but do not know what might happen. I urgently need help from someone

        • 1. Re: interrup high speed

          When you upload here your project so that we all might have a look at we could probably give you some advice. Please use the "Create Workspace Bundle" (minimal) function of Creator 2.2.








          PS Good afternoon? My watch shows 22:05, it is pitch dark outside.

          • 2. Re: interrup high speed

            The interrupt latency in Cortex M3 is 12 cycles, take a look at this -




            http://www.arm.com/files/pdf/introToCortex-M3.pdf page 7




            Additionally the ISR latency is a function of what you do in it. Hopefully


            you are not calling any API's from within it, which results in stack push,


            and of course the latency due to the API code. Normally what you want


            optimally is to set a flag in ISR and return, and then process in main.




            It is incorrect to assume ISRs are not sensitive to rate, they get


            latched by HW but other processes and ISR activity may rob MIPS from


            CPU to service. I assume your priority is highest level for this ISR.




            Lastly at 1 Mhz you need to count cycles in code to see what your latency


            is. If it is too great then resort to HW to handle the sampling of the data I


            assume you are doing. Verilog of course very useful here.




            Regards, Dana.

            • 3. Re: interrup high speed

               Good afternoon, I am Colombian, I dont have good English, I hope  you understand


              I will comment that my project is to know how I can help.




              I have two rotary encoder, they send the absolute position by a frame of serial data by a Manchester code, the encoders are of 11 bits.




              To get the position, I decode the signal. The Manchester decoder is not the problem, the problem is the timing, and for that I get a interrup for rising edge  and falling edge  to synchronize the decoder.


              The delivery code encoder is shown in Figure




              I must get the data (15 bits) of the first frame.


              I do not know what idea you have to be able to help.




              Attached two codes


              One simulates the clock and then with a interrup on and off an output pin.


              The other has a signal input to the decoder.




              none works.