element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • 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 & Tria Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • About Us
  • 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
      • Japan
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      • Vietnam
      • 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 & Tria Boards Community
  • Avnet Boards Forums
  • More
  • Cancel
Avnet Boards Forums
MicroZed Hardware Design Bidirectional GPIO using EMIO
  • 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 Verified Answer
  • Replies 1 reply
  • Subscribers 341 subscribers
  • Views 1266 views
  • Users 0 members are here
Related

Bidirectional GPIO using EMIO

Former Member
Former Member over 9 years ago

I am working on a project that requires a large number of bidirectional GPIO pins so I have to use EMIO instead of MIO to get access to the FMC Carrier Card PMOD pins.

I have GPIO output working on the EMIO pins by setting the GPIO_O port as external and configuring the sites in Implemented Design.
But how can I make the pins bidirectional? The PS block doesn't have a GPIO_Bidirectional port.

  • Sign in to reply
  • Cancel

Top Replies

  • zedhed
    zedhed over 9 years ago +1 verified
    Hi bb, I am going to assume that you are using Vivado Design Suite for your design and that bidirectional means that there is an input, an output, and a tristate signal which can connect to an IOBUF primitive…
  • zedhed
    0 zedhed over 9 years ago

    Hi bb,

    I am going to assume that you are using Vivado Design Suite for your design and that bidirectional means that there is an input, an output, and a tristate signal which can connect to an IOBUF primitive so that you can select which direction the GPIO is intended to go. 

    In your block design, you can enable EMIO GPIO from the PS7 IP configuration window which enables a set of EMIO GPIO ports (likely named GPIO_0) on the PS7 block.

    You can then right click on that GPIO_0 port (all of the wires are grouped together) and select "Make External" to create an external port for them and automatically connect wires to the external port.  I like to name my EMIO GPIO ports "emio_user" since I usually connect them to the user LEDs, DIP switches, and Push Buttons of a board for demos.

    That's it!

    When you create the wrapper for the block design, Vivado automatically picks up on the GPIO_I, GPIO_O, and GPIO_T signals and tries to pack them into IOBUF primitives for you, like this:

    emio_user_tri_iobuf_8: component IOBUF
         port map (
          I => emio_user_tri_o_8(8),
          IO => emio_user_tri_io(8),
          O => emio_user_tri_i_8(8),
          T => emio_user_tri_t_8(8)
        );

    Now all you need to do is to make sure that you have the matching constraints for those external nets and you have bidirectional ports.

    Regards,

    -Kevin

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Reject 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