element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • About Us
  • Community Hub
    Community Hub
    • What's New on element14
    • Feedback and Support
    • Benefits of Membership
    • Personal Blogs
    • Members Area
    • Achievement Levels
  • Learn
    Learn
    • Ask an Expert
    • eBooks
    • element14 presents
    • Learning Center
    • Tech Spotlight
    • STEM Academy
    • Webinars, Training and Events
    • Learning Groups
  • Technologies
    Technologies
    • 3D Printing
    • FPGA
    • Industrial Automation
    • Internet of Things
    • Power & Energy
    • Sensors
    • Technology Groups
  • Challenges & Projects
    Challenges & Projects
    • Design Challenges
    • element14 presents Projects
    • Project14
    • Arduino Projects
    • Raspberry Pi Projects
    • Project Groups
  • Products
    Products
    • Arduino
    • Avnet Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • Store
    Store
    • Visit Your Store
    • Choose another store...
      • Europe
      •  Austria (German)
      •  Belgium (Dutch, French)
      •  Bulgaria (Bulgarian)
      •  Czech Republic (Czech)
      •  Denmark (Danish)
      •  Estonia (Estonian)
      •  Finland (Finnish)
      •  France (French)
      •  Germany (German)
      •  Hungary (Hungarian)
      •  Ireland
      •  Israel
      •  Italy (Italian)
      •  Latvia (Latvian)
      •  
      •  Lithuania (Lithuanian)
      •  Netherlands (Dutch)
      •  Norway (Norwegian)
      •  Poland (Polish)
      •  Portugal (Portuguese)
      •  Romania (Romanian)
      •  Russia (Russian)
      •  Slovakia (Slovak)
      •  Slovenia (Slovenian)
      •  Spain (Spanish)
      •  Sweden (Swedish)
      •  Switzerland(German, French)
      •  Turkey (Turkish)
      •  United Kingdom
      • Asia Pacific
      •  Australia
      •  China
      •  Hong Kong
      •  India
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      • Americas
      •  Brazil (Portuguese)
      •  Canada
      •  Mexico (Spanish)
      •  United States
      Can't find the country/region you're looking for? Visit our export site or find a local distributor.
  • Translate
  • Profile
  • Settings
Avnet Boards Forums
  • Products
  • Dev Tools
  • Avnet Boards Community
  • Avnet Boards Forums
  • More
  • Cancel
Avnet Boards Forums
Software Application Development maximum interrupt frequency using timer interrupt
  • Forum
  • Documents
  • Members
  • Mentions
  • Sub-Groups
  • Tags
  • More
  • Cancel
  • New
Join Avnet Boards Forums to participate - click to join for free!
Actions
  • Share
  • More
  • Cancel
Forum Thread Details
  • State Not Answered
  • Replies 1 reply
  • Subscribers 328 subscribers
  • Views 464 views
  • Users 0 members are here
Related

maximum interrupt frequency using timer interrupt

Former Member
Former Member over 9 years ago

Hi,

The zynq processor is running at 666MHz. I like to sample an ADC every 20 KHz (ISR is called every 20 KHz). I set my processor's timer to

XScuTimer_LoadTimer(&my_Timer, 16667);

Is this even possible?

I tried to measure how many cycle it takes from one interrupt to another one using

#include "xtime_l.h"
XTime tStart;

//and I call my ISR (interrupt Handler), the following

XTime_GetTime(&tStart);

//and print the following

xil_printf("Output took %d clock cycles.
", (int) tStart);

// Results
//Output took 171859333 clock cycles.
//Output took 175360259 clock cycles.

// If I calculate the sampling rate it gives the following

// 666666666/(2*(175360259- 171859333)) = 95.23 

I cannot get more than this value. If I set my timer value to

XScuTimer_LoadTimer(&my_Timer, XPAR_PS7_CORTEXA9_0_CPU_CLK_FREQ_HZ / 2)

I can easily measure how fast interrupt handler gets executed. In this case I would get 1 Hz.

Is there something wrong in the way I measure the cycle elapsed? Can anyone have a better way to measure how fast timer interrupt calls interrupt handler?

Itried to toggle an PMOD pin, I am not able to toggle the pin more than 87 Hz.

I appreciate your help in advance.

Thank you,

  • Sign in to reply
  • Cancel
  • Former Member
    0 Former Member over 9 years ago

    Hello,

     

    If you are looking for a literal answer to your question on using the zynq processor timer you will probably have a broader and more knowledgeable audience on one of the Xilinx Community forums as this is not specific to one of the 'zed boards.

     

    https://forums.xilinx.com/

     

     

    If you are looking for an easy way to observe exactly when your timer generates an interrupt you might want to consider using one of the Zynq triple timers. The counter output on the triple timers can be routed directly a Zynq package pin (MIO or EMIO for timer 0 and EMIO for timer 1/2) that you could observe with an oscilloscope (or using Vivado Analyzer in the Zynq PL via EMIO connections).

     

    -Gary

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
element14 Community

element14 is the first online community specifically for engineers. Connect with your peers and get expert answers to your questions.

  • Members
  • Learn
  • Technologies
  • Challenges & Projects
  • Products
  • Store
  • About Us
  • Feedback & Support
  • FAQs
  • Terms of Use
  • Privacy Policy
  • Legal and Copyright Notices
  • Sitemap
  • Cookies

An Avnet Company © 2025 Premier Farnell Limited. All Rights Reserved.

Premier Farnell Ltd, registered in England and Wales (no 00876412), registered office: Farnell House, Forge Lane, Leeds LS12 2NE.

ICP 备案号 10220084.

Follow element14

  • X
  • Facebook
  • linkedin
  • YouTube