mikroC PRO for dsPIC30/33 and PIC24 is a full-featured C compiler
for dsPIC30, dsPIC33 and PIC24 MCUs from Microchip. It is designed
for developing, building and debugging dsPIC30/33 and PIC24based embedded applications. This development environment has a
wide range of features such as: easy-to-use IDE, very compact and
efcient code, many hardware and software libraries, comprehensive
documentation, software simulator, COFF le generation, SSA
optimization (up to 30% code reduction) and many more. Numerous
ready-to-use and well-explained examples will give a good start for
your embedded project.
Manual
Compiler
MikroElektronika
mikoC PRO for dsPIC
Table of Contents
CHAPTER 1 32
INTRODUCTION 32
Introduction to mikroC PRO for dsPIC30/33 and PIC24 33
Features 33
Where to Start 33
What’s new in mikroC PRO for dsPIC30/33 and PIC24 34
Compiler Changes 34
IDE Changes 34
Software License Agreement 35
mikroElektronika Associates License Statement and Limited Warranty 35
IMPORTANT - READ CAREFULLY 35
LIMITED WARRANTY 35
HIGH RISK ACTIVITIES 36
GENERAL PROVISIONS 36
Technical Support 37
How to Register 37
Who Gets the License Key 37
How to Get License Key 37
After Receving the License Key 39
CHAPTER 2 41
mikroC PRO for dsPIC30/33 and PIC24 Environment 41
Main Menu Options 42
File 43
File Menu Options 43
Edit 44
Edit Menu Options 44
Find Text 45
Replace Text 45
Find In Files 46
Go To Line 46
Regular expressions option 46
View 47
View Menu Options 47
Project 49
Project Menu Options 49
Build 50
Build Menu Options 50
Run 51
Run Menu Options 51
Tools 52
Tools Menu Options 52
MikroElektronika
2
mikroC PRO for dsPIC
Help 53
Help Menu Options 53
mikroC PRO for dsPIC30/33 and PIC24 IDE 54
IDE Overview 54
Code Editor 55
Editor Settings 55
Auto Save 56
Highlighter 56
Spelling 56
Comment Style 56
Code Folding 56
Code Assistant 57
Parameter Assistant 57
Bookmarks 57
Go to Line 57
Column Select Mode 58
Editor Colors 58
Auto Correct 59
Auto Complete (Code Templates) 60
Memory Usage Windows 68
RAM Memory Usage 69
Used RAM Locations 69
SFR Locations 70
ROM Memory Usage 70
ROM Memory Constants 71
Functions 71
Functions Sorted By Name Chart 72
Functions Sorted By Size Chart 72
Functions Sorted By Addresses 73
Function Tree 73
Memory Summary 74
Types Efciency 164
Nested Calls Limitations 164
Limits of Indirect Approach Through PSV 164
Limits of Pointer to Function 164
Variable, constant and routine alignment 164
dsPIC Memory Organization 165
Program Memory (ROM) 165
Data Memory (RAM) 166
SFR Memory Space 166
X and Y Data RAM 166
DMA RAM 167
Unimplemented Memory Space 167
Pointer Declarations 206
Null Pointers 207
Assign an address to a Function Pointer 207
Function Pointers 209
Assign an address to a Function Pointer 209
Pointer Arithmetic 210
Arrays and Pointers 210
Assignment and Comparison 211
Pointer Addition 212
Pointer Subtraction 213
Structures 213
Structure Declaration and Initialization 213
Incomplete Declarations 214
Untagged Structures and Typedefs 215
Anonymous Structures 215
Working with Structures 216
Assignment 216
Size of Structure 216
Structures and Functions 216
Using Microchip MPLAB® IDE with mikroElektronika compilers 766
Debugging Your Code 766
Using MPLAB® ICD 2 Debugger 766
Using MPLAB® Simulator 773
MikroElektronika
30
mikroC PRO for dsPIC
Frequently Asked Questions 778
Can I use your compilers and programmer on Windows Vista (Windows 7) ? 778
I am getting “Access is denied” error in Vista, how to solve this problem ? 778
What are differences between mikroC PRO, mikroPascal PRO and mikroBasic PRO compilers ?
Why do they have different prices ? 778
Why do your PIC compilers don’t support 12F508 and some similar chips ? 778
What are limitations of demo versions of mikroElektronika’s compilers ? 778
Why do I still get demo limit error when I purchased and installed license key ? 778
I have bought license for the older version, do I have to pay license for the new version of the compiler ? 779
Do your compilers work on Windows Vista (Windows 7) ? 779
What does this function/procedure/routine do ? 779
I try to compile one of the provided examples and nothing happens, what is the problem? 779
Can I get your library sources ? I need to provide all sources with my project. 779
Can I use code I developed in your compilers in commercial purposes ? Are there some limitations
? 779
Why does an example provided with your compilers doesn’t work ? 779
Your example works if I use the same MCU you did, but how to make it work for another MCU ? 779
I need this project nished, can you help me ? 780
Do you have some discount on your compilers/development systems for students/professors ? 780
I have a question about your compilers which is not listed here. Where can I nd an answer ? 780
31
MikroElektronika
mikoC PRO for dsPIC
CHAPTER 1
INTRODUCTION
The mikroC PRO for dsPIC30/33 and PIC24 is a powerful, feature-rich development tool for dsPIC30/33 and PIC24
microcontrollers. It is designed to provide the programmer with the easiest possible solution to developing applications
for embedded systems, without compromising performance or control.
mikroC PRO for dsPIC30/33 and PIC24 IDE
MikroElektronika
32
mikroC PRO for dsPIC
Introduction to mikroC PRO for dsPIC30/33 and PIC24
dsPIC30/33 and PIC24 and C t together well: dsPIC is designed as PIC with digital signal processing capabilities.
These are Microchip’s rst inherent 16-bit (data) microcontrollers. They build on the PIC’s existing strength offering
hardware MAC (multiply-accumulate), barrel shifting, bit reversal, (16x16)-bit multiplication and other digital signal
processing operations. Having a wide range of application, being prized for its efciency, dsPIC30/33 and PIC24 MCUs
are a natural choice for developing embedded systems. mikroC PRO for dsPIC30/33 and PIC24 provides a successful
match featuring highly advanced IDE, ANSI compliant compiler, broad set of hardware libraries, comprehensive
documentation, and plenty of ready-to-run examples.
Features
mikroC PRO for dsPIC30/33 and PIC24 allows you to quickly develop and deploy complex applications:
- Write your source code using the built-in Code Editor (Code and Parameter Assistants, Code Folding,
Syntax Highlighting, Auto Correct, Code Templates, and more.)
- Use included mikroC PRO for dsPIC30/33 and PIC24 libraries to dramatically speed up the development:
data acquisition, memory, displays, conversions, communication etc.
- Monitor your program structure, variables, and functions in the Code Explorer.
- Generate commented, human-readable assembly, and standard HEX compatible with all programmers.
- Use the integrated mikroICD (In-Circuit Debugger) Real-Time debugging tool to monitor program execution
on the hardware level.
- Inspect program ow and debug executable logic with the integrated Software Simulator.
- Generate COFF(Common Object File Format) le for software and hardware debugging under Microchip’s
MPLAB software.
- Use Single Static Assignment optimization to shrink your code to even smaller size.
- Get detailed reports and graphs: RAM and ROM map, code statistics, assembly listing, calling tree,
and more.
- Active Comments enable you to make your comments alive and interactive.
- mikroC PRO for dsPIC30/33 and PIC24 provides plenty of examples to expand, develop, and use as
building bricks in your projects. Copy them entirely if you deem t – that’s why we included them
with the compiler.
Where to Start
- In case that you’re a beginner in programming dsPIC30/33 and PIC24 microcontrollers, read carefully the
dsPIC Specics chapter. It might give you some useful pointers on dsPIC30/33 and PIC24 constraints,
code portability, and good programming practices.
- If you are experienced in C programming, you will probably want to consult mikroC PRO for dsPIC30/33
and PIC24 Specics rst. For language issues, you can always refer to the comprehensive Language
Reference. A complete list of included libraries is available at mikroC PRO for dsPIC30/33 and PIC24 Libraries.
- If you are not very experienced in C programming, don’t panic! mikroC PRO for dsPIC30/33 and PIC24
provides plenty of examples making it easy for you to go quickly. We suggest that you rst consult Projects
and Source Files, and then start browsing the examples that you’re the most interested in.
Copyright (c) 2002-2010 mikroElektronika. All rights reserved.
What do you think about this topic ? Send us feedback!
33
MikroElektronika
mikoC PRO for dsPIC
What’s new in mikroC PRO for dsPIC30/33 and PIC24
IDE build 4.60
Command line build 4.60
New features and enhancements in the following areas will boost your productivity by helping you complete many tasks
more easily and in less time.
For a complete version history of mikroC PRO for dsPIC30/33 and PIC24, visit the following link : http://www.mikroe.
com/download/eng/documents/compilers/mikroc/pro/dspic/version_history.txt
- Compiler Changes
- IDE Changes
Compiler Changes
Fixed :
- Optimization issues in specic cases when destination variable is in Rx space.
- Alignment not set for the rst variable which is the rst in block of initializers.
IDE Changes
Fixed :
- Error in Code Explorer in case void interrup is dened (without brackets).
- Compiler version is not visible in caption if no projects are open.
- Parameter assistant ignores commas when switching to another parameter.
- Occasional lost of conguration ags when swithing between projets.
- Improper display of RAM memory usage in statistics.
Improved :
- Communication to programmer concerning supported chips.
- License Key Request form.
MikroElektronika
34
mikroC PRO for dsPIC
Software License Agreement
mikroElektronika Associates License Statement and Limited Warranty
IMPORTANT - READ CAREFULLY
This license statement and limited warranty constitute a legal agreement (“License Agreement”) between you (either as
an individual or a single entity) and mikroElektronika (“mikroElektronika Associates”) for software product (“Software”)
identied above, including any software, media, and accompanying on-line or printed documentation.
BY INSTALLING, COPYING, OR OTHERWISE USING SOFTWARE, YOU AGREE TO BE BOUND BY ALL TERMS
AND CONDITIONS OF THE LICENSE AGREEMENT.
Upon your acceptance of the terms and conditions of the License Agreement, mikroElektronika Associates grants you
the right to use Software in a way provided below.
This Software is owned by mikroElektronika Associates and is protected by copyright law and international copyright
treaty. Therefore, you must treat this Software like any other copyright material (e.g., a book).
You may transfer Software and documentation on a permanent basis provided. You retain no copies and the recipient
agrees to the terms of the License Agreement. Except as provided in the License Agreement, you may not transfer,
rent, lease, lend, copy, modify, translate, sublicense, time-share or electronically transmit or receive Software, media
or documentation. You acknowledge that Software in the source code form remains a condential trade secret of
mikroElektronika Associates and therefore you agree not to modify Software or attempt to reverse engineer, decompile,
or disassemble it, except and only to the extent that such activity is expressly permitted by applicable law notwithstanding
this limitation.
If you have purchased an upgrade version of Software, it constitutes a single product with the mikroElektronika
Associates software that you upgraded. You may use the upgrade version of Software only in accordance with the
License Agreement.
LIMITED WARRANTY
Respectfully excepting the Redistributables, which are provided “as is”, without warranty of any kind, mikroElektronika
Associates warrants that Software, once updated and properly used, will perform substantially in accordance with the
accompanying documentation, and Software media will be free from defects in materials and workmanship, for a period
of ninety (90) days from the date of receipt. Any implied warranties on Software are limited to ninety (90) days.
mikroElektronika Associates’ and its suppliers’ entire liability and your exclusive remedy shall be, at mikroElektronika
Associates’ option, either (a) return of the price paid, or (b) repair or replacement of Software that does not meet
mikroElektronika Associates’ Limited Warranty and which is returned to mikroElektronika Associates with a copy of
your receipt. DO NOT RETURN ANY PRODUCT UNTIL YOU HAVE CALLED MIKROELEKTRONIKA ASSOCIATES
FIRST AND OBTAINED A RETURN AUTHORIZATION NUMBER. This Limited Warranty is void if failure of Software
has resulted from an accident, abuse, or misapplication. Any replacement of Software will be warranted for the rest of
the original warranty period or thirty (30) days, whichever is longer.
TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, MIKROELEKTRONIKA ASSOCIATES AND ITS
SUPPLIERS DISCLAIM ALL OTHER WARRANTIES AND CONDITIONS, EITHER EXPRESSED OR IMPLIED,
INCLUDED, BUT NOT LIMITED TO IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
PURPOSE, TITLE, AND NON-INFRINGEMENT, WITH REGARD TO SOFTWARE, AND THE PROVISION OF OR
FAILURE TO PROVIDE SUPPORT SERVICES.
35
MikroElektronika
mikoC PRO for dsPIC
IN NO EVENT SHALL MIKROELEKTRONIKA ASSOCIATES OR ITS SUPPLIERS BE LIABLE FOR ANY SPECIAL,
INCIDENTAL, INDIRECT, OR CONSEQUENTIAL DAMAGES WHATSOEVER (INCLUDING, WITHOUT LIMITATION,
DAMAGES FOR LOSS OF BUSINESS PROFITS AND BUSINESS INFORMATION, BUSINESS INTERRUPTION, OR
ANY OTHER PECUNIARY LOSS) ARISING OUT OF THE USE OF OR INABILITY TO USE SOFTWARE PRODUCT
OR THE PROVISION OF OR FAILURE TO PROVIDE SUPPORT SERVICES, EVEN IF MIKROELEKTRONIKA
ASSOCIATES HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. IN ANY CASE, MIKROELEKTRONIKA
ASSOCIATES’ ENTIRE LIABILITY UNDER ANY PROVISION OF THIS LICENSE AGREEMENT SHALL BE LIMITED
TO THE AMOUNT ACTUALLY PAID BY YOU FOR SOFTWARE PRODUCT PROVIDED, HOWEVER, IF YOU HAVE
ENTERED INTO A MIKROELEKTRONIKA ASSOCIATES SUPPORT SERVICES AGREEMENT, MIKROELEKTRONIKA
ASSOCIATES’ ENTIRE LIABILITY REGARDING SUPPORT SERVICES SHALL BE GOVERNED BY THE TERMS OF
THAT AGREEMENT.
HIGH RISK ACTIVITIES
Software is not fault-tolerant and is not designed, manufactured or intended for use or resale as on-line control
equipment in hazardous environments requiring fail-safe performance, such as in the operation of nuclear facilities,
aircraft navigation or communication systems, air trafc control, direct life support machines, or weapons systems, in
which the failure of Software could lead directly to death, personal injury, or severe physical or environmental damage
(“High Risk Activities”). mikroElektronika Associates and its suppliers specically disclaim any expressed or implied
warranty of tness for High Risk Activities.
GENERAL PROVISIONS
This statement may only be modied in writing signed by you and an authorised ofcer of mikroElektronika Associates.
If any provision of this statement is found void or unenforceable, the remainder will remain valid and enforceable
according to its terms. If any remedy provided is determined to have failed for its essential purpose, all limitations of
liability and exclusions of damages set forth in the Limited Warranty shall remain in effect.
This statement gives you specic legal rights; you may have others, which vary, from country to country. mikroElektronika
Associates reserves all rights not specically granted in this statement.
The latest software can be downloaded free of charge via Internet (you might want to bookmark the page so you could
check news, patches, and upgrades later on): www.mikroe.com/en/compilers/mikroC PRO/dspic/download.htm .
In case you encounter any problem, you are welcome to our support forums at www.mikroe.com/forum/. Here, you may
also nd helpful information, hardware tips, and practical code snippets. Your comments and suggestions on future
development of the mikroC PRO for dsPIC30/33 and PIC24 are always appreciated — feel free to drop a note or two
on our Wishlist.
In our Knowledge Base www.mikroe.com/en/kb/ you can nd the answers to Frequently Asked Questions and solutions
to known problems. If you can not nd the solution to your problem in Knowledge Base then report it to Support Desk
www.mikroe.com/en/support/. In this way, we can record and track down bugs more efciently, which is in our mutual
interest. We respond to every bug report and question in a suitable manner, ever improving our technical support.
How to Register
The latest version of the mikroC PRO for dsPIC30/33 and PIC24 is always available for downloading from our website.
It is a fully functional software with the mikroICD(in-circuit Debugger), all the libraries, examples, and comprehensive
help included.
The only limitation of the free version is that it cannot generate hex output over 2K of program words. Although it might
sound restrictive, this margin allows you to develop practical, working applications with no thinking of demo limit. If you
intend to develop really complex projects in the mikroC PRO for dsPIC30/33 and PIC24, then you should consider the
possibility of purchasing the license key.
Who Gets the License Key
Buyers of the mikroC PRO for dsPIC30/33 and PIC24 are entitled to the license key. After you have completed the
payment procedure, you have an option of registering your mikroC PRO for dsPIC30/33 and PIC24. In this way you can
generate hex output without any limitations.
How to Get License Key
After you have completed the payment procedure, start the program. Select Help › How to Register from the drop-
down menu or click the How To Register Icon .
You can choose between two registering methods, I work online or I work ofine, based on your current internet
connection and click Request license key now button :
37
MikroElektronika
mikoC PRO for dsPIC
If you choose I work online registering method, following page will be opened in your default browser :
MikroElektronika
38
mikroC PRO for dsPIC
Fill out the registration form, select your distributor, and click the Submit button.
If you choose I work ofine registering method, following window will be opened :
Fill out the registration form, select your distributor, and click the Submit button.
This will start your e-mail client with message ready for sending. Review the information you have entered, and add the
comment if you deem it necessary. Please, do not modify the subject line.
Upon receiving and verifying your request, we will send the license key to the e-mail address you specied in the
form.
After Receving the License Key
The license key comes as a small autoextracting le – just start it anywhere on your computer in order to activate
your copy of compiler and remove the demo limit. You do not need to restart your computer or install any additional
components. Also, there is no need to run the mikroC PRO for dsPIC30/33 and PIC24 at the time of activation.
39
MikroElektronika
mikoC PRO for dsPIC
Important :
- The license key is valid until you format your hard disk. In case you need to format the hard disk,
you should request a new activation key.
- Please keep the activation program in a safe place. Every time you upgrade the compiler
you should start this program again in order to reactivate the license.
MikroElektronika
40
mikroC PRO for dsPIC
CHAPTER 2
mikroC PRO for dsPIC30/33 and
PIC24 Environment
41
MikroElektronika
Main Menu Options
Available Main Menu options are:
mikoC PRO for dsPIC
Related topics: Keyboard shortcuts, Toolbars
MikroElektronika
42
mikroC PRO for dsPIC
File
File Menu Options
The File menu is the main entry point for manipulation with the source les.
FileDescription
Open a new editor window.
Open source le for editing or image le for viewing.
Reopen recently used le.
Save changes for active editor.
Save the active source le with the different name or change the le type.
Close active source le.
Close all opened les.
Print Preview.
Print.
Exit IDE.
Related topics: Keyboard shortcuts, File Toolbar, Managing Source Files
43
MikroElektronika
Edit
Edit Menu Options
The Edit Menu contains commands for editing the contents of the current document.
mikoC PRO for dsPIC
EditDescription
Undo last change.
Redo last change.
Cut selected text to clipboard.
Copy selected text to clipboard.
Paste text from clipboard.
Delete selected text.
Select all text in active editor.
Find text in active editor.
Find next occurence of text in active editor.
Find previous occurence of text in active editor.
Replace text in active editor.
Find text in current le, in all opened les, or in les from desired folder.
Go to line to the desired line in active editor.
Advanced Code Editor options
MikroElektronika
44
mikroC PRO for dsPIC
Advanced »Description
Comment selected code or put single line comment if there is no selection.
Uncomment selected code or remove single line comment if there is no selection.
Indent selected code.
Outdent selected code.
Changes selected text case to lowercase.
Changes selected text case to uppercase.
Changes selected text case to titlercase.
Find Text
Dialog box for searching the document for the specied text. The search is performed in the direction specied. If the
string is not found a message is displayed.
Replace Text
Dialog box for searching for a text string in le and replacing it with another text string.
45
MikroElektronika
mikoC PRO for dsPIC
Find In Files
Dialog box for searching for a text string in current le, all opened les, or in les on a disk.
The string to search for is specied in the Text to nd eld. If Search in directories option is selected, The les to search
are specied in the Files mask and Path elds.
Go To Line
Dialog box that allows the user to specify the line number at which the cursor should be positioned.
Regular expressions option
By checking this box, you will be able to advance your search, through Regular expressions.
Related topics: Keyboard shortcuts, Edit Toolbar, Advanced Edit Toolbar
MikroElektronika
46
mikroC PRO for dsPIC
View
View Menu Options
View Menu contains commands for controlling the on-screen display of the current project.
The Tools toolbar can easily be customized by adding new tools in Options(F12) window.
Related topics: Keyboard shortcuts, Integrated Tools
MikroElektronika
48
mikroC PRO for dsPIC
Project
Project Menu Options
Project Menu allows user to easily manipulate current project.
ProjectDescription
Open New Project Wizard
Open existing project.
Open project group.
Open recently used project or project group.
Save current project.
Save active project le with the different name.
Close active project.
Close project group.
Add le to project.
Remove le from project.
Edit search paths.
Edit project settings
Clean Project Folder
Export Project.
Related topics: Keyboard shortcuts, Project Toolbar, Creating New Project, Project Manager, Project Settings
49
MikroElektronika
Build
Build Menu Options
Build Menu allows user to easily manage building and compiling process.
BuildDescription
Build active project.
Rebuild all sources in acrive project.
Build all projects.
Stop building of all projects.
mikoC PRO for dsPIC
Build and program active project.
Related topics: Keyboard shortcuts, Project Toolbar, Creating New Project, Project Manager, Project Settings
MikroElektronika
50
mikroC PRO for dsPIC
Run
Run Menu Options
Run Menu is used to debug and test compiled code on a software or harware level.
RunDescription
Start Software Simulator or mikroICD (In-Circuit Debugger).
Stop debugger.
Run/Pause Debugger.
Step Into.
Step Over.
Step Out.
Run To Cursor.
Jump to interrupt in current project.
Toggle Breakpoint.
Clear Breakpoints.
Toggle between source and disassembly.
Related topics: Keyboard shortcuts, Debug Toolbar
51
MikroElektronika
mikoC PRO for dsPIC
Tools
Tools Menu Options
Tools Menu contain a number of applications designed to ease the use of compiler and included library routines.
ToolsDescription
Run mikroElektronika Programmer.
Run Package Manager.
Show/Hide Active Comment Editor window.
Run ASCII Chart
Run EEPROM Editor
Generate HTML code suitable for publishing source code on the web.
Run Filter Designer Tool.
Run Glcd bitmap editor
Run HID Terminal
Run Lcd custom character
Run Seven Segment Editor
Run UDP communication terminal
Run USART Terminal
Open Options window
Related topics: Keyboard shortcuts, Tools Toolbar
MikroElektronika
52
mikroC PRO for dsPIC
Help
Help Menu Options
HelpDescription
Оpen Help File.
Оpen Code Migration Document.
Check if new compiler version is available.
Open mikroElektronika Support Forums in a default browser.
Open mikroElektronika Web Page in a default browser.
Information on how to register
Open About window.
Related topics: Keyboard shortcuts, Help Toolbar
53
MikroElektronika
mikoC PRO for dsPIC
mikroC PRO for dsPIC30/33 and PIC24 IDE
IDE Overview
The mikroC PRO for dsPIC30/33 and PIC24 is an user-friendly and intuitive environment.
For a detailed information on a certain part of IDE, simply click on it (hovering a mouse cursor above a desired IDE part
will pop-up its name) :
- The Code Editor features adjustable Syntax Highlighting, Code Folding, Code Assistant, Parameters Assistant, Spell
Checker, Auto Correct for common typos and Code Templates (Auto Complete).
- The Code Explorer is at your disposal for easier project management.
- The Project Manager alows multiple project management
- General project settings can be made in the Project Settings window
- Library manager enables simple handling libraries being used in a project
- The Messages Window displays all messages during compiling and linking.
- The source-level Software Simulator lets you debug executable logic step-by-step by watching the program ow.
- The New Project Wizard is a fast, reliable, and easy way to create a project.
- Help les are syntax and context sensitive.
- Like in any modern Windows application, you may customize the layout of mikroC PRO for dsPIC30/33 and PIC24
to suit your needs best.
- Spell checker underlines identiers which are unknown to the project. In this way it helps the programmer to spot
potential problems early, much before the project is compiled.
Spell checker can be disabled by choosing the option in the Preferences dialog (F12).
MikroElektronika
54
mikroC PRO for dsPIC
Code Editor
The Code Editor is advanced text editor fashioned to satisfy needs of professionals. General code editing is the
same as working with any standard text-editor, including familiar Copy, Paste and Undo actions, common for Windows
environment.
Available Code Editor options are: Editor Settings, Editor Colors, Auto Correct, Auto Complete and Style.
Editor Settings
Main Editor Settings Features are :
- Auto Save
- Highlighter
- Spelling
- Comment Style
- Code Folding
- Code Assistant
- Parameter Assistant
- Bookmarks and Go to Line
55
MikroElektronika
mikoC PRO for dsPIC
Auto Save
Auto Save is a function which saves an opened project automatically, helping to reduce the risk of data loss in case of
a crash or freeze. Autosaving is done in time intervals dened by the user.
Highlighter
Highlighting is a convenient feature for spotting brackets which notate begin or end of a routine, by making them
visually distinct.
Spelling
The Spell Checker underlines unknown objects in the code, so they can be easily noticed and corrected before compiling
your project.
Select Tools › Options from the drop-down menu, or click the Show Options Icon and then select the Spell
Checker Tab.
Comment Style
Code Editor has a feature to change the comment style to either single-line or multi-line. Commenting or uncommenting
the selected code is done by a simple click of a mouse, using the Comment Icon and Uncomment Icon from
the Advanced Edit Toolbar.
Code Folding
Code folding is IDE feature which allows users to selectively hide and display sections of a source le. In this way it is
easier to manage large regions of code within one window, while still viewing only those subsections of the code that
are relevant during a particular editing session.
While typing, the code folding symbols ( and ) appear automatically. Use the folding symbols to hide/unhide the
code subsections.
MikroElektronika
56
mikroC PRO for dsPIC
Another way of folding/unfolding code subsections is by using Alt+← and Alt+→.
If you place a mouse cursor over the tooltip box, the collapsed text will be shown in a tooltip style box.
Code Assistant
If you type the rst few letters of a word and then press Ctrl+Space, all valid identiers matching the letters you have
typed will be prompted in a oating panel (see the image below). Now you can keep typing to narrow the choice, or you
can select one from the list using the keyboard arrows and Enter.
Parameter Assistant
The Parameter Assistant will be automatically invoked when you open parenthesis “(” or press Shift+Ctrl+Space. If the
name of a valid function precedes the parenthesis, then the expected parameters will be displayed in a oating panel.
As you type the actual parameter, the next expected parameter will become bold.
Bookmarks
Bookmarks make navigation through a large code easier. To set a bookmark, use Ctrl+Shift+number. The same
princliple applies to the removal of the bookmarks. To jump to a bookmark, use Ctrl+number.
Go to Line
The Go to Line option makes navigation through a large code easier. Use the shortcut Ctrl+G to activate this option.
57
MikroElektronika
mikoC PRO for dsPIC
Column Select Mode
This mode changes the operation of the editor for selecting text. When column select mode is used, highlighted text
is based on the character column position of the rst character selected to the column of the last character of text
selected.
Text selected in this mode does not automatically include all text between the start and end position, but includes all
text in the columns between the rst and last character selected.
Column mode editing is sometimes referred to as block mode editing as the act of selecting text forms a rectangle.
To enter this mode, press Alt + Left mouse button, drag the mouse towards the desired direction thus selecting the
text.
Editor Colors
MikroElektronika
58
mikroC PRO for dsPIC
Editor Colors option allows user to set, change and save text and color settings organized in schemes. Schemes
represent custom graphical appearance that can be applied to GUI(Graphical User Interface) to satifsy tastes of
different users.
Auto Correct
Auto Correct option facilitate user in such a fashion that it automatically corrects common typing or spelling errors as
it types.
This option is already set up to automatically correct some words. For example, if you type whiel, it will be corrected to
while when you press the spacebar :
59
MikroElektronika
mikoC PRO for dsPIC
User can easily add its common typos by entering original typo, for example btye, to the Original box, and replacement,
byte, to the Replacement box, and just click "Add" button.
Next time when the typo occurs, it will be automatically corrected.
Auto Complete (Code Templates)
Auto Complete option saves lots of keystrokes for commonly used phrases by automatically completing user's typing.
MikroElektronika
60
mikroC PRO for dsPIC
User can insert the Code Template by typing the name of the template (for instance, dow), then press Ctrl+J and the
Code Editor will automatically generate a code :
You can add your own templates to the list by entering the desired keyword, description and code of your template in
appropriate boxes.
Autocomplete macros can retreive system and project information :
- %DATE% - current system date
- %TIME% - current system time
- %DEVICE% - device(MCU) name as specied in project settings
- %DEVICE_CLOCK% - clock as specied in project settings
- %COMPILER% - current compiler version
These macros can be used in template code, see template ptemplate provided with mikroC PRO for dsPIC30/33 and
PIC24 installation.
61
MikroElektronika
mikoC PRO for dsPIC
Code Explorer
The Code Explorer gives clear view of each item declared inside the source code. You can jump to a declaration of
any item by double clicking it, or pressing the Enter button. Also, besides the list of dened and declared objects, code
explorer displays message about rst error and it's location in code.
Following options are available in the Code Explorer:
Icon Description
Expand/Collapse all nodes in tree.
Locate declaration in code.
MikroElektronika
62
mikroC PRO for dsPIC
Routine List
Routine list diplays list of routines, and enables ltering routines by name. Routine list window can be accessed by
pressing Ctrl+L.
You can jump to a desired routine by double clicking on it, or pressing the Enter button. Also, you can sort routines by
size or by address.
Project Manager
Project Manager is IDE feature which allows users to manage multiple projects. Several projects which together make
project group may be open at the same time. Only one of them may be active at the moment.
Setting project in active mode is performed by double clicking the desired project in the Project Manager, which will
result in bolding the project's name.
Also, the name of the currently active project will be diplayed in the Program Manager window title, alongside with the
number of projects in project group.
63
MikroElektronika
Following options are available in the Project Manager:
IconDescription
mikoC PRO for dsPIC
For details about adding and removing les from project see Add/Remove Files from Project.
Save project Group.
Open project group.
Close the active project.
Close project group.
Add project to the project group.
Remove project from the project group.
Add le to the active project.
Remove selected le from the project.
Build the active project.
Run mikroElektronika’s Flash programmer.
Related topics: Project Settings, Project Menu Options, File Menu Options, Project Toolbar, Build Toolbar, Add/Remove
Files from Project
MikroElektronika
64
mikroC PRO for dsPIC
Project Settings
Following options are available in the Project Settings :
- Device - select the appropriate device from the device drop-down list.
- MCU Clock - enter the clock frequency value.
- Build/Debugger Type - choose debugger type.
Related topics: Edit Project, Customizing Projects, Project Manager
65
MikroElektronika
mikoC PRO for dsPIC
Library Manager
Library Manager enables simple handling libraries being used in a project. Library Manager window lists all libraries
(extension .mcl) which are instantly stored in the compiler Uses folder. The desirable library is added to the project by
selecting check box next to the library name.
In order to have all library functions accessible, simply press the button Check All and all libraries will be selected.
In case none library is needed in a project, press the button ClearAll and all libraries will be cleared from the
project.
Only the selected libraries will be linked.
IconDescription
Refresh Library by scanning les in “Uses” folder.Useful when new libraries are added by copying les to
“Uses” folder.
Rebuild all available libraries. Useful when library sources are available and need refreshing.
Include all available libraries in current project.
No libraries from the list will be included in current project.
Restore library to the state just before last project saving.
MikroElektronika
66
mikroC PRO for dsPIC
Managing libraries using Package Manager
The Package Manager is a tool which enables users to easily install their own libraries in the mikroIDE. Libraries are
distributed in the form of a package, which is an archive composed of one or more les, containing libraries. For more
information on Package Manager, visit our website.
Upon package installation, a new node with the package name will be created in the Library Manager. For example :
From the Library Manager, user can also uninstall the desired package by right clicking the the appropriate node, and
from the drop-down menu choose Uninstall package :
67
MikroElektronika
Related topics: mikroC PRO for PIC Libraries, Creating New Library
mikoC PRO for dsPIC
Statistics
After successful compilation, you can review statistics of your code. Click the Statistics Icon .
Memory Usage Windows
Provides overview of RAM and ROM usage in the various forms.
MikroElektronika
68
mikroC PRO for dsPIC
RAM Memory Usage
Displays RAM memory usage in a pie-like form.
Used RAM Locations
Displays used RAM memory locations and their names.
69
MikroElektronika
SFR Locations
Displays list of used SFR locations.
mikoC PRO for dsPIC
ROM Memory Usage
Displays ROM memory space usage in a pie-like form.
MikroElektronika
70
mikroC PRO for dsPIC
ROM Memory Constants
Displays ROM memory constants and their addresses.
Functions
Sorts and displays functions in various ways.
71
MikroElektronika
Functions Sorted By Name Chart
Sorts and displays functions by their name, in the ascending order.
mikoC PRO for dsPIC
Functions Sorted By Size Chart
Sorts and displays functions by their sizes in a chart-like form.
MikroElektronika
72
mikroC PRO for dsPIC
Functions Sorted By Addresses
Sorts and displays functions by their addresses, in the ascending order.
Function Tree
Displays Function Tree with the relevant data for each function.
73
MikroElektronika
Memory Summary
Displays summary of RAM and ROM memory in a pie-like form.
mikoC PRO for dsPIC
MikroElektronika
74
mikroC PRO for dsPIC
Messages Window
Messages Window displays various informations and notications about the compilation process.
It reports for example, time needed for preprocessing, compilation and linking; used RAM and ROM space, generated
baud rate with error percentage, etc.
User can lter which notications will Messages Window display by checking Errors, Warning and Hints box.
In case that errors were encountered during compiling, the compiler will report them and won’t generate a hex le. The
Messages Window will display errros at the bottom of the window by default.
The compiler also reports warnings, but these do not affect the output; only errors can interefere with the generation
of hex.
Double click the message line in the Message Window to highlight the line where the error was encountered.
75
MikroElektronika
mikoC PRO for dsPIC
Quick Converter
Quick Converter enables user to easily transform numbers from one base to another.
User can convert integers of various sizes (8, 16 or 32 bits), signed and unsigned, using different representation
(decimal, hexadecimal, binary and character).
Also, Quick Converter features oat point numbers conversion from/to Float Decimal, Float 32bit (IEEE), Float 32bit
(Microchip) and Radix 1.15 for dsPIC family of MCUs.
Macro Editor
A macro is a series of keystrokes that have been 'recorded' in the order performed. A macro allows you to 'record' a
series of keystrokes and then 'playback', or repeat, the recorded keystrokes.
MikroElektronika
76
mikroC PRO for dsPIC
The Macro offers the following commands:
IconDescription
Related topics: Code Editor, Code Templates
Starts ‘recording’ keystrokes for later playback.
Stops capturing keystrokes that was started when the Start Recording command was selected.
Allows a macro that has been recorded to be replayed.
New macro.
Delete macro.
Image Preview
There are a lot of occassions in which the user besides the code, must look at the appropriate schematics in order to
succesfully write the desired program.
The mikroC PRO for dsPIC30/33 and PIC24 provides this possibility through a Image Preview Window.
To add a image to the Image Preview Window, right click the Image Files node in the Project Manager :
77
MikroElektronika
Now, navigate to the desired image le, and simply add it :
Next, right click the added le, and choose Set As Preview Image :
mikoC PRO for dsPIC
MikroElektronika
78
mikroC PRO for dsPIC
Once you have added the image, it will appear in the Image Preview Window :
Also, you can add multiple images to the Image Files node, but only the one that is set will be automatically displayed
in the Image Preview Window upon opening the project.
By changing the Image Preview Window size, displayed image will be t by its height in such a way that its proportions
will remain intact.
Toolbars
This section provides an overview of the toolbars available in mikroC PRO for dsPIC30/33 and PIC24 Help :
- File Toolbar
- Edit Toolbar
- Advanced Edit Toolbar
- Find Toolbar
- Project Toolbar
- Build Toolbar
- Debug Toolbar
- Styles Toolbar
- Tools Toolbar
- View Toolbar
- Layout Toolbar
- Help Toolbar
79
MikroElektronika
File Toolbar
File Toolbar is a standard toolbar with following options:
IconDescription
mikoC PRO for dsPIC
Opens a new editor window.
Open source le for editing or image le for viewing.
Save changes for active window.
Save changes in all opened windows.
Print Preview.
Print.
Edit Toolbar
Edit Toolbar is a standard toolbar with following options:
IconDescription
Undo last change.
Redo last change.
Cut selected text to clipboard.
Copy selected text to clipboard.
Paste text from clipboard.
MikroElektronika
80
mikroC PRO for dsPIC
Advanced Edit Toolbar
Advanced Edit Toolbar comes with following options:
IconDescription
Comment selected code or put single line comment if there is no selection
Uncomment selected code or remove single line comment if there is no selection.
Select text from starting delimiter to ending delimiter.
Go to ending delimiter.
Go to line.
Indent selected code lines.
Outdent selected code lines.
Generate HTML code suitable for publishing current source code on the web.
Find/Replace Toolbar
Find/Replace Toolbar is a standard toolbar with following options:
IconDescription
Find text in current editor.
Find next occurence.
Find previous occurence.
Replace text.
Find text in les.
81
MikroElektronika
Project Toolbar
Project Toolbar comes with following options:
IconDescription
mikoC PRO for dsPIC
New project.
Open Project
Save Project
Edit project settings.
Close current project.
Clean project folder.
Add File To Project
Remove File From Project
Build Toolbar
Build Toolbar comes with following options:
IconDescription
Build current project.
Build all opened projects.
Build and program active project.
Start programmer and load current HEX le.
MikroElektronika
82
mikroC PRO for dsPIC
Debug Toolbar
Debug Toolbar comes with following options:
IconDescription
Start Software Simulator or mikroICD (In-Circuit Debugger).
Run/Pause Debugger.
Stop Debugger.
Step Into.
Step Over.
Step Out.
Run To Cursor.
Toggle Breakpoint.
View Breakpoints Window
Clear Breakpoints.
View Watch Window
View Stopwatch Window
Styles Toolbar
Styles toolbar allows you to easily change colors of your workspace.
83
MikroElektronika
Tools Toolbar
Tools Toolbar comes with following default options:
IconDescription
mikoC PRO for dsPIC
Tip : The Tools toolbar can easily be customized by adding new tools in Options menu window.
Run USART Terminal
EEPROM
ASCII Chart
Seven Segment Editor.
Open Active Comment editor.
Options menu
View Toolbar
View Toolbar provides access to assembly code, listing le and statistics windows.
IconDescription
Open assembly code in editor.
Open listing le in editor.
View statistics for current project.
MikroElektronika
84
mikroC PRO for dsPIC
Layout Toolbar
Styles toolbar allows you to easily customize workspace through a number of different IDE layouts.
Help Toolbar
Help Toolbar provides access to information on using and registering compilers :
IconDescription
Related topics: Keyboard shortcuts, Integrated Tools
Open Help le.
How To Register.
85
MikroElektronika
mikoC PRO for dsPIC
Customizing IDE Layout
Docking Windows
You can increase the viewing and editing space for code, depending on how you arrange the windows in the IDE.
Step 1: Click the window you want to dock, to give it focus.
Step 2: Drag the tool window from its current location. A guide diamond appears. The four arrows of the diamond point
towards the four edges of the IDE.
MikroElektronika
86
mikroC PRO for dsPIC
Step 3: Move the pointer over the corresponding portion of the guide diamond. An outline of the window appears in the
designated area.
Step 4: To dock the window in the position indicated, release the mouse button.
Tip : To move a dockable window without snapping it into place, press CTRL while dragging it.
Saving Layout
Once you have a window layout that you like, you can save the layout by typing the name for the layout and pressing
the Save Layout Icon .
To set the layout select the desired layout from the layout drop-down list and click the Set Layout Icon .
To remove the layout from the drop-down list, select the desired layout from the list and click the Delete Layout
Icon .
Auto Hide
Auto Hide enables you to see more of your code at one time by minimizing tool windows along the edges of the IDE
when not in use.
- Click the window you want to keep visible to give it focus.
- Click the Pushpin Icon on the title bar of the window.
87
MikroElektronika
mikoC PRO for dsPIC
When an auto-hidden window loses focus, it automatically slides back to its tab on the edge of the IDE. While a window
is auto-hidden, its name and icon are visible on a tab at the edge of the IDE. To display an auto-hidden window, move
your pointer over the tab. The window slides back into view and is ready for use.
Options
Options menu consists of three tabs: Code Editor, Tools and Output settings
Code editor
The Code Editor is advanced text editor fashioned to satisfy needs of professionals.
Tools
The mikroC PRO for dsPIC30/33 and PIC24 includes the Tools tab, which enables the use of shortcuts to external
programs, like Calculator or Notepad.
You can set up to 10 different shortcuts, by editing Tool0 - Tool9.
MikroElektronika
88
mikroC PRO for dsPIC
Output settings
By modifying Output Settings, user can congure the content of the output les.
You can enable or disable, for example, generation of ASM and List le.
Also, user can choose optimization level, and compiler specic settings, which include case sensitivity, dynamic link for
string literals setting (described in mikroC PRO for dsPIC30/33 and PIC24 specics).
Build all les as library enables user to use compiled library (*.mcl) on any MCU (when this box is checked), or for a
selected MCU (when this box is left unchecked).
For more information on creating new libraries, see Creating New Library.
89
MikroElektronika
mikoC PRO for dsPIC
MikroElektronika
90
mikroC PRO for dsPIC
Integrated Tools
Active Comments Editor
Active Comments Editor is a tool, particularly useful when working with Lcd display. You can launch it from the drop-
down menu Tools › Active Comments Editor or by clicking the Active Comment Editor Icon from Tools toolbar.
91
MikroElektronika
mikoC PRO for dsPIC
ASCII Chart
The ASCII Chart is a handy tool, particularly useful when working with Lcd display. You can launch it from the drop-
down menu Tools › ASCII chart or by clicking the View ASCII Chart Icon from Tools toolbar.
MikroElektronika
92
mikroC PRO for dsPIC
EEPROM Editor
The EEPROM Editor is used for manipulating MCU's EEPROM memory. You can launch it from the drop-down menu
Tools › EEPROM Editor.
When you run mikroElektronika programmer software from mikroC PRO for dsPIC30/33 and PIC24 IDE - project_
name.hex le will be loaded automatically while ihex le must be loaded manually.
Filter Designer
The Filter designer is a tool for designing FIR and IIR lters. It has an user-friendly visual interface for setting the lter
parameters. Filter designer output is the mikroC PRO for dsPIC30/33 and PIC24 compatible code. You can launch it
from the drop-down menu Tools › Filter Designer.
93
MikroElektronika
mikoC PRO for dsPIC
Graphic Lcd Bitmap Editor
The mikroC PRO for dsPIC30/33 and PIC24 includes the Graphic Lcd Bitmap Editor. Output is the mikroC PRO for
dsPIC30/33 and PIC24 compatible code. You can launch it from the drop-down menu Tools › Glcd Bitmap Editor.
MikroElektronika
94
mikroC PRO for dsPIC
HID Terminal
The mikroC PRO for dsPIC30/33 and PIC24 includes the HID communication terminal for USB communication. You
can launch it from the drop-down menu Tools › HID Terminal.
95
MikroElektronika
mikoC PRO for dsPIC
Lcd Custom Character
mikroC PRO for dsPIC30/33 and PIC24 includes the Lcd Custom Character. Output is mikroC PRO for dsPIC30/33 and
PIC24 compatible code. You can launch it from the drop-down menu Tools › Lcd Custom Character.
MikroElektronika
96
mikroC PRO for dsPIC
Seven Segment Editor
The Seven Segment Editor is a convenient visual panel which returns decimal/hex value for any viable combination you
would like to display on seven segment display. Click on the parts of seven segment image to get the requested value
in the edit boxes. You can launch it from the drop-down menu Tools › Seven Segment Editor or by clicking the Seven
Segment Editor Icon from Tools toolbar.
UDP Terminal
The mikroC PRO for dsPIC30/33 and PIC24 includes the UDP Terminal. You can launch it from the drop-down menu
Tools › UDP Terminal.
97
MikroElektronika
mikoC PRO for dsPIC
USART Terminal
The mikroC PRO for dsPIC30/33 and PIC24 includes the USART communication terminal for RS232 communication.
You can launch it from the drop-down menu Tools › USART Terminal or by clicking the USART Terminal Icon from
Tools toolbar.
MikroElektronika
98
mikroC PRO for dsPIC
Active Comments
The idea of Active Comments is to make comments alive and give old fashioned comments new meaning and look.
From now on, you can assign mouse event on your comments and 'tell' your comments what to do on each one. For
example, on left mouse click, open some web address in your browser, on mouse over show some picture and on
mouse double click open some le.
Let suppose we are writing a example for a GSM/GPSR module which is connected to EasyPIC6 and we would like to
provide a photo of our hardware (jumpers, cables, etc.). within the example.
Also, it would be also nice to put some documentation about chip we are using and a GSM module extra board. Now
we can have all those things dened in one single comment using Active Comment Editor.
New Active Comment
When you start Active Comment Editor for the rst time (from the View menu, from editor's pop-up menu, or by pressing
Ctrl + Alt + P) you will get an empty editor :
By clicking the button you are prompted to enter a name for the comment :
99
MikroElektronika
mikoC PRO for dsPIC
You can notice that when you start typing a name, properties pane is automatically displayed so you can edit properties
if you wish. A Comment will be is created when you click button.
Properties are consisted of two major categories - Attributes and Events.
Attributes can be :
- URL - Valid web address.
- Image - Image has to be previously added to Project (Project Manager > Images).
- File - File has to be previously added to Project (Project Manager > Other Files).
There are four predened event types you can apply to an Active Comment :
1. OnLeftClick + Alt
2. OnRightClick
3. OnDoubleClick
4. OnMouseOver
MikroElektronika
100
Loading...
+ hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.