In my previous column, we discussed the concept of hardware-assisted debuggers. As usual, an interesting discussion ensued, and this provided a good opportunity to share our experiences. Now, let's proceed with our "10 Commandments" and move on to consider Question No. 4 as follows:
No. 4: What's your (the vendor's) experience with IP cores?
For many of us, our hair is not so long as it used to be, and our trousers are not as roomy as they once were, all of which means... we’re getting more experienced. Similarly, I won’t be revealing any secrets if I say that the more experience a third-party IP core vendor has, the better. Only experienced engineers can develop robust and reliable IP core products that are verified and silicon-proven.
Now, some may say, "These words are just slogans; where are the facts?" Well, I think it's fair to say that experience almost certainly equates to having worked on interesting projects. Do you remember our previous discussions in which we considered the pros and cons of designing everything oneself? And if we were to ask ourselves how many projects we've worked on in our lives, what would be the answer?
All of this forms the basis of today’s blog: Experience -- in the context of a third-party IP core developer -- means having an experienced engineering team that has successfully implemented a wide variety of different and demanding projects. In the case of my company, Digital Core Designs (DCD), let me briefly mention a few such projects as follows:
How about a microcontroller core that can execute instructions in a single clock period and is able to run at over 310MHz in a worst-case 180nm process technology? In this particular project, the technology timing was a real issue for the customer. In order to fulfil the requirements, we had to duplicate some of the processor resources so as to enable the whole system to run at these extremely high (for this process technology) frequencies.
Many times, the most challenging projects involve developing IP cores for devices with synchronous core functions, when these devices have traditionally been asynchronous (latch-based) or even of an analog nature. A really good example of such an IP core would be the HC11 microcontroller. The 68HC11 originally had on-chip ADCs (analog-to-digital converters) and EEPROM memory, but most FPGA devices don’t offer modules that can be used as replacements for this functionality. Moreover, the users of such systems require full software compatibility with the original devices.
In order to fulfill such requirements, we replaced the ADC from the original HC11 with an external serial ADC. The resulting D68HC11 IP core has a built-in dedicated ADC controller, which automatically communicates with the external ADC and lets the user/programmer control the entire ADC module exactly as it was done in the original HC11. Similarly, in the case of the EEPROM, the D68HC11 core contains an EEPROM controller, which communicates with an external serial EEPROM and controls it fully in the hardware.
In some cases, systems with a slow-running clock source can present interesting challenges. On a number of occasions, for example, we have been presented with customer applications that required the microcontroller to run at a very low frequency -- perhaps around 1kHz. The problem was that these customers also wanted to have access to a built-in, real-time, on-chip debugger. As you can imagine, debugging code using a debugger running at 1kHz would provide what could only be described as a traumatic experience.
The solution was to create a system that employed two separate clocks -- a slow clock to drive the CPU and a fast clock for communication with the host PC. Although this may sound simple, it does involve some complexities, such as the CPU and the hardware-assisted debugger both requiring control over the same internal CPU resources. In this particular case, we had to implement a handshaking mechanism in order to make sure that all the commands of the debugger would be executed.
Why not couple an 8051 MCU with a DFPMU-DP? A few years ago (2004, to be precise) we designed our DP8051XP core connected to a double-precision coprocessor (DFPMU-DP) in a GPS system. The whole package was cleverly designed to work both with a standard 8051 C compiler and with double-precision numbers (64-bits in size). This particular example proved that an 8-bit CPU embedded with a double-precision coprocessor could be used in a GPS system implemented in a 130nm ASIC process technology.
The main advantage of this approach was that the system consumed extremely low power and utilized an extremely small amount of area on the silicon die. It's worth mentioning that this project occurred in the electronic equivalent of the Late Middle Ages when GPS devices were nowhere near as popular as they are today.
So, just to summarize this topic, an experienced third-party IP core vendor will always encourage its customers to discuss their specifications. Doing so, the vendor can configure its IP cores to provide the most adapted solution and to deliver reusable IP cores that can be integrated seamlessly into the final design. A knowledgeable and skilled IP core development team will always be able to adapt to new requirements based on their previous experiences.
@Hash.era. If you feel that 3rd party involvement might be risky, don't risk ;) Of course you might feel that it's risky, but my job is to convince you that 3rd party IP vendor is here to help you, not to hamper. I can just say that most of our customers are "returning" customers - if our cooperation would be risky for their projects, I bet they wouldn't get back to us.
hash.era 2/3/2013 12:01:15 PM User Rank Clever Clogs
Re: Who said cats lead boring lives anyway?
Jacek: I think there is a huge amount of risk involved eventhough its not been highlighted here isnt it ? 3rd party involvements to projects like this is very risky.
Jacek Hanke 1/31/2013 2:37:27 AM User Rank Blogger
Re: Who said cats lead boring lives anyway?
@hash.era This could be a tricky situation for both sides, cause sometimes exposure of our IP can be abused by a potential customer. That's why the trust and 3rd party experience becomes crucial here. As for an example, we're building our brand since 1999 and every project brings profits both for our customers and our R&D team. Every success story, every successful design and every "satisfied" engineer build a brand. And it's a neverending story, cause it takes years to build and seconds to ruin. I prefer building :)
hash.era 1/30/2013 10:11:06 AM User Rank Clever Clogs
Re: Who said cats lead boring lives anyway?
Jacek: Any 3rd party involvement is a risk since you will be exposing your data / information / codes to them as well. It might not be a 100% give away but yet small parts are enough if the 3rd party is smarter than you.
Jacek, thanks for sharing your personal details. I had forwarded the details to our evaluation and procurement division. They will get in touch with you, if required. Otherwise if you would like to share some of your product details, you can always mail to abeyjacob3 at yahoo dot com
In order to implement the components of a new chip design, any IP core should be delivered with everything needed to design, test, and validate that core in the target product.
If you are interested in licensing a third-party IP core, it's a good idea to ensure that the vendor can also supply you with the debugger. The ideal situation is to obtain the debugger together with the IP core -- all from one vendor.
To save this item to your list of favorite All Programmable Planet content so you can find it later in your Profile page, click the "Save It" button next to the item.
If you found this interesting or useful, please use the links to the services below to share it with other readers. You will need a free account with each service to share an item via that service.