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 Implement Custom Peripheral as a driver
  • 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 6 replies
  • Subscribers 328 subscribers
  • Views 446 views
  • Users 0 members are here
Related

Implement Custom Peripheral as a driver

Former Member
Former Member over 12 years ago

Hi,

to implement custom peripherals in bare metal is no problem, but what if one want to implement a peripheral as a driver for the embedded linux?
I'll be grateful for any help,
Gerd

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

    This way has worked for me,

    Add your peripherals in the .dts-file, e.g. for my motor-controller block I add (under the AMBA/AXI-bus depending on which release):


    motor_control_bdc_6wheels@40000000{
      compatible = "digster,motor-control-bdc-6wheels-1.00.a";
      reg = <0x40000000 0x1000>;
    };

    where the reg-parameter specifies the <baseAddress memorySpace>.

    For writing the actual driver, I used http://wiki.xilinx.com/gpio-user-space-app to create a user-space driver. Not optimal but still... More information is available in other topics about ioremap() e.g.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 12 years ago

    This (http://www.zedboard.org/content/recompile-linux-kernel) forum thread helped me a lot when customizing the Linux experience.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 12 years ago

    TY for the help.
    Where did you get:
    motor_control_bdc_6wheels@40000000{
    compatible = "digster,motor-control-bdc-6wheels-1.00.a";
    reg = <0x40000000 0x1000>;
    };

    from?
    But in order to make the dtb file consistent with the pl portion i have to modify the boot file with the .bit file for the configuration, right?

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 12 years ago in reply to Former Member

    motor_control_bdc_6wheels is the name of my IP-block name. @40000000 is just the HEX address. Inside the {} i just tried to edit another entry to fit my block. The compatible somehow points to the driver/developer of the block, and I wrote it as "project name,driver name".
    The reg parameter is just <base address, address space>

    Regarding the bit-file/dtb-file consistency, the dts/dtb should of course be representing your current bit file (not entirely necessary but should be). So yes, the boot.bin needs to be updated with your *.bit-file.

    However, I think (not entirely sure, could check later) that the device-tree could be left as it is as long as you are providing your own driver with HARD CODED addresses and such. The device tree is only for writing generic drivers. (Someone else might say that I'm wrong about this however...) 

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 12 years ago

    It worked, i implemented the simple_register example as linux driver with your guidance, but when it came to the software i sticked to this: http://wiki.xilinx.com/osl-user-mode-pseudo-driver
    and i managed to strip the out put of the register to the leds. now that this is working, other things will work as well in the future

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 12 years ago in reply to Former Member

    Hi Gerd86,

    I am trying to do the same with no luck.  I am trying to implement the simple register in linux but get a segmentation fault when I try to read/write it.  Can you provide the source code of what you did to get it to work?  Thanks.

    • 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