Programming Arduino Projects with the PIC Microcontroller: A Line-by-Line Code Analysis and Complete Reference Guide for Embedded Programming in C
()
About this ebook
You'll review and work with several Arduino projects plus two extra ones written for a PIC microcontroller. Each one is accompanied with a basic circuit diagram and photos of the program working. Ideal for the Arduino hobbyist and PIC programmers who want to merge their skills, this comprehensive book will go over every aspect of the 8-bit microcontroller, provide line-by-line analysis of the code, and in the end, show you how to bring your Arduino projects to the PIC microcontroller using C. You'll gain a full understanding of how the C instructions work and can be used with the PIC microcontroller.
Programming Arduino Projects with the PIC Microcontroller is your one-stop reference resource.
What You’ll Learn
- Examine how the code works
- Create code to perform any function
- Build practical projects on vero boards with full vero plans and circuit diagrams
- Understand how programs work by simulation with an ECAD package
Would-be embedded programmers, Arduino hobbyists, and PIC programmers.
Read more from Hubert Henry Ward
C Programming for the PIC Microcontroller: Demystify Coding with Embedded Programming Rating: 0 out of 5 stars0 ratingsIntermediate C Programming for the PIC Microcontroller: Simplifying Embedded Programming Rating: 0 out of 5 stars0 ratings
Related to Programming Arduino Projects with the PIC Microcontroller
Related ebooks
C Programming for the Pc the Mac and the Arduino Microcontroller System Rating: 0 out of 5 stars0 ratingsPic® Micro Principles Teachers Pack V11 Rating: 0 out of 5 stars0 ratingsPic® Micro Principles on Your Mobile Rating: 0 out of 5 stars0 ratingsLearn the Pic® Micro on Your Smartphone Rating: 0 out of 5 stars0 ratingsPic® Micro Principles V11 Rating: 0 out of 5 stars0 ratingsBeginning Robotics with Raspberry Pi and Arduino: Using Python and OpenCV Rating: 0 out of 5 stars0 ratingsIntelligence Devices for Smart World Rating: 0 out of 5 stars0 ratingsArduino Applied: Comprehensive Projects for Everyday Electronics Rating: 0 out of 5 stars0 ratingsRaspberry Pi IoT Projects: Prototyping Experiments for Makers Rating: 0 out of 5 stars0 ratingsArduino Electronics Blueprints Rating: 4 out of 5 stars4/5ESP32 Programming for the Internet of Things: JavaScript, AJAX, MQTT and WebSockets Solutions Rating: 5 out of 5 stars5/5PLC Programming Using SIMATIC MANAGER for Beginners: With Basic Concepts of Ladder Logic Programming Rating: 4 out of 5 stars4/5Foundation Course for Advanced Computer Studies Rating: 0 out of 5 stars0 ratingsWindows 10 for the Internet of Things: Controlling Internet-Connected Devices from Raspberry Pi Rating: 0 out of 5 stars0 ratingsMaking PIC Microcontroller Instruments and Controllers Rating: 0 out of 5 stars0 ratingsPractical Arduino Robotics: A hands-on guide to bringing your robotics ideas to life using Arduino Rating: 0 out of 5 stars0 ratingsBuild Logic Gates with Universal NAND: CMOS and TTL in Action Rating: 0 out of 5 stars0 ratingsARDUINO CODE: Mastering Arduino Programming for Embedded Systems (2024 Guide) Rating: 0 out of 5 stars0 ratingsMicroPython Projects: A do-it-yourself guide for embedded developers to build a range of applications using Python Rating: 0 out of 5 stars0 ratingsMastering Linux Device Driver Development: Write custom device drivers to support computer peripherals in Linux operating systems Rating: 0 out of 5 stars0 ratingsIntroduction to TinyML Rating: 5 out of 5 stars5/5Programming Basics: Getting Started with Java, C#, and Python Rating: 0 out of 5 stars0 ratingsRP2040 Assembly Language Programming: ARM Cortex-M0+ on the Raspberry Pi Pico Rating: 0 out of 5 stars0 ratingsProgramming Microcontrollers with Python: Experience the Power of Embedded Python Rating: 0 out of 5 stars0 ratingsBeginning Arduino Nano 33 IoT: Step-By-Step Internet of Things Projects Rating: 0 out of 5 stars0 ratings
Hardware For You
Raspberry Pi Electronics Projects for the Evil Genius Rating: 3 out of 5 stars3/5CompTIA A+ Complete Review Guide: Exam Core 1 220-1001 and Exam Core 2 220-1002 Rating: 5 out of 5 stars5/5Electrical Engineering | Step by Step Rating: 0 out of 5 stars0 ratingsChip War: The Fight for the World's Most Critical Technology Rating: 4 out of 5 stars4/5iPhone 16 Pro Max User Manual: The Complete Step-By-Step Guide to Maximize your New iPhone 16 Pro Max and iOS 18 Rating: 0 out of 5 stars0 ratingsHelp! iOS 17 - iPhone: How to Use iOS17 Rating: 0 out of 5 stars0 ratingsRaspberry Pi Cookbook for Python Programmers Rating: 0 out of 5 stars0 ratingsmacOS Sonoma For Dummies Rating: 0 out of 5 stars0 ratingsMacBook For Dummies Rating: 4 out of 5 stars4/5CompTIA A+ Complete Review Guide: Core 1 Exam 220-1101 and Core 2 Exam 220-1102 Rating: 5 out of 5 stars5/5Exploring Arduino: Tools and Techniques for Engineering Wizardry Rating: 4 out of 5 stars4/5iPhone For Seniors For Dummies: Updated for iPhone 12 models and iOS 14 Rating: 4 out of 5 stars4/5Build Your Own PC Do-It-Yourself For Dummies Rating: 4 out of 5 stars4/5Chromebook For Dummies Rating: 5 out of 5 stars5/5Switching to a Mac For Dummies Rating: 0 out of 5 stars0 ratingsiPhone For Dummies Rating: 0 out of 5 stars0 ratingsExploring Apple iPad: iPadOS 15 Edition: The Illustrated, Practical Guide to Using your iPad Rating: 0 out of 5 stars0 ratingsProgramming Arduino: Getting Started with Sketches Rating: 4 out of 5 stars4/5Amazon Web Services (AWS) Interview Questions and Answers Rating: 5 out of 5 stars5/5iPhone X Hacks, Tips and Tricks: Discover 101 Awesome Tips and Tricks for iPhone XS, XS Max and iPhone X Rating: 3 out of 5 stars3/5Arduino Electronics Blueprints Rating: 4 out of 5 stars4/5Tor Darknet Bundle: Master the Art of Invisibility Rating: 0 out of 5 stars0 ratingsTroubleshooting and Maintaining Your PC All-in-One For Dummies Rating: 5 out of 5 stars5/5iMac For Dummies Rating: 0 out of 5 stars0 ratingsAfter Steve: How Apple Became a Trillion-Dollar Company and Lost Its Soul Rating: 4 out of 5 stars4/5Laptops For Dummies Rating: 5 out of 5 stars5/5
Reviews for Programming Arduino Projects with the PIC Microcontroller
0 ratings0 reviews
Book preview
Programming Arduino Projects with the PIC Microcontroller - Hubert Henry Ward
© The Author(s), under exclusive license to APress Media, LLC, part of Springer Nature 2022
H. H. WardProgramming Arduino Projects with the PIC Microcontrollerhttps://doi.org/10.1007/978-1-4842-7230-5_1
1. Introducing MPLABX
Hubert Henry Ward¹
(1)
Leigh, UK
In this chapter we are going to learn about the MPLABX, an industrial integrated development environment (IDE) from Microchip. We will learn what an IDE is and how to create a project with MPLABX. We will also learn about the configuration bits for programmable interrupt controller (PIC) micros. Finally, we will learn about header files: why we use them and how to create one in MPLABX.
MPLABX: The IDE from Microchip
An IDE is actually a collection of the different programs needed to write program instructions in our chosen language, and then convert them to the actual machine code that the micro understands and also link together any bits of program we may want to use.
The programs we need in the IDE are as follows:
A text editor to write the instructions for the program. Note that the simple text editor Notepad could be used, but the text editor in MPLABX is by far a more advanced text editor.
A compiler to change the instructions into a format the micro can understand.
A linker to combine any files the programmer wants to use.
A driver that will allow the programming tool we use to load the program into the micro.
A variety of debug tools to allow the programmer to test the program live within the micro.
All these are in, or should be in, the IDE we choose to use. Microsoft has Visual Studio, Microchip has MPLABX, and Freescale uses CodeWarrior. The Arduino has its own IDE. There is also CODEBLOCK, which is an IDE for writing generic ‘C’ programs that will run on your PC. As this book is based on the PIC micro, we will concentrate on MPLABX. MPLABX has an improved text editor to give the text different color codes when we save the file as an .asm or .c for c program file, such as light blue for keywords, light gray for comments, and so on.
There are some other organization programs within MPLABX, such as those that support the ability to write to the configuration registers for the PIC. There is also the ability to debug your programs within the IDE. All this makes MPLABX a useful tool for programming PICs.
There is also a program called MCC (Microchip Code Configurator). This will actually produce a lot of the code you need to use various aspects of the PIC. However, I firmly believe that you should produce the code you use yourself so that you fully understand it. I will not cover the use of MCC. Also, Microchip has not written the MCC for all its PICs, and the 18F4525 is one it has missed so far. Really, when asked who the programmer is, you should be able to say that you are and not the MCC. When you take the time to study how to write your own code, you will find it is not as hard as you first thought. Also you will get a better self-reward if you write it all yourself.
The only aspect of the programs that I let Microchip do for me is to write the code configuration bits that set up the PIC. This is only because it is so simple to do this and it covers all the #pragma statements that we used to write ourselves.
Creating a Project in MPLABX
Once you have downloaded both the MPLABX software and the XC8 (V2.10) compiler software or XC8 (V1.35), when you open the software the opening screen will be as shown in Figure 1-1.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig1_HTML.jpgFigure 1-1
The opening screen in MPLABX
The project window on the left-hand side may not be shown. If you want it shown, then you should select the word window
from the top menu bar. You should then click the mouse on the word projects
, with the orange boxes in front of it, and the window should appear. You may have to move the window about to get it in the position shown.
Now, assuming you are ready to create a project, you should either click the mouse on the word file
, in the main menu bar, and select new project, or click the mouse on the orange box, with the small green cross, on the second menu bar. This is the second symbol from the left-hand side of the second menu bar.
When you have selected the create project option, you should now see the window shown in Figure 1-2.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig2_HTML.jpgFigure 1-2
The new project window
Most of the projects we will create are Microchip Embedded and Standalone. Therefore, make sure these two options are highlighted and then click Next
. The select device window should now be visible as shown in Figure 1-3.
Figure 1-3
The select device window
In this window, we can choose which PIC we want to use. For our first project, we are going to use the PIC16F88 micro. You need to select the midrange eight-bit MCUs (PIC10, 12, 16/MCP) in the small box alongside Family, as shown in Figure 1-3. Then, in the device window, you need to select the PIC16F88. The result is shown in Figure 1-3. To make these options visible, you need to click the small downward-pointing arrows in the respective boxes. The different options should then become visible. If the device window is highlighted in blue, you could simply type in the PIC number you want (i.e., PIC16F88). Your selected device should appear in the window shown in Figure 1-3.
If you are using a different PIC then you should select it here.
Once you are happy with your selection, you need to click the next box in the window.
The next window to appear is the select tool window. This is shown in Figure 1-4. With this window, you can select the programming tool you want to use to download the program to your prototype board. There are a range of tools you can use. I mainly use the ICD3 CAN or the PICkit3 tool. We will select the PICkit3 as shown in Figure 1-4. If you are using a different tool to download your program, simply select it here. Do not worry if you don’t see the serial number of your device, as shown in Figure 1-4. This would be because you have not yet connected it to your laptop.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig4_HTML.jpgFigure 1-4
The select tool window
Having selected the tool you want, simply click Next
to move on to the next window, where you can select the compiler software you want to use, assuming you have downloaded the appropriate compiler software.
Figure 1-5
The select compiler window
You should select the XC8 (V2.20) compiler software, although with some later projects we will use V1.35, as shown in Figure 1-5. Then click Next
to move to the select project name and folder window, as shown in Figure 1-6.
Figure 1-6
The select project name and folder window
In this window, you will specify the name of the project and where you want to save it. The software will create a new directory on your computer with the project name you create here. It is not recommended to use long-winded complicated path names to the new folder, so I normally save all my projects on the root directory of my laptop.
I have suggested a project name for this new project as ourFirst16F88. Note that I am using camel case, in which two words, or more, are combined together. The first letter of the first word is in lowercase and the first letters of any subsequent words are in uppercase. In this way, multiple words can be combined together to make one long word.
As you type the name for your project you should see that the folder is created on the root drive, or wherever you have specified it should be. The folder name will have a .X added to it.
It will be in this new folder that all the files associated with the project will be saved as well as some important subdirectories that are created.
Once you are happy with the naming of the project, simply click Finish
and the project will be created. The window will now go back to the main window as shown in Figure 1-7.
Figure 1-7
The main window with the project created
You should now see the project window at the left-hand side of your screen as shown in Figure 1-7. Note that you may need to move the window around to get it the same in Figure 1-7.
The Configuration Words
This section discusses one of the major differences between the PIC microcontrollers and the Arduino. It may seem rather cumbersome, but it reflects the versatility of PICs. It will also give me an opportunity to introduce you to header files and show you how we can create them.
With the Arduino, it is most likely that the configuration work has been done for you; this may make it seem that the Arduino is easier to use. However, I think it has removed the versatility of the device and restricts your understanding of the microcontroller. Certainly, MPLABX, the industrial IDE developed by Microchip, does not have any preconfigured setups for their PICs. This does give you the full range of their versatility, but it does mean you have an extra bit of studying to do before you can program the PICs. Thankfully, it is not a lot to study and Microchip has made it very easy for you to configure the PICs as you want.
The configuration words actually configure, or set up, certain aspects of the PIC and how we want to use them. The most important of these aspects is the source of the oscillator we will be using. The oscillator produces the clocking signal that synchronizes all the actions of the PIC. Microchip allows us to choose from a very wide range of sources from the simple RC (resistor capacitor) oscillator, for low frequencies that don’t need to be very accurate, to the more accurate crystal oscillators with frequencies above 20Mhz. These are external devices that can be connected to the PIC. However, Microchip also gives us the choice of using oscillators that are internal (i.e., already set up inside the PIC). This can save the cost of buying an oscillator and save the use of two pins that would have to be used to connect an external oscillator to the PIC. When you use the Arduino, you don’t have to worry about which oscillator source you are using because you have had that choice done for you.
There are other aspects of the PIC you need to configure, such as the WDT (watch dog timer) and the Low Voltage Programming (LVP); we will look at them now.
I have tried to explain the use of the configuration words; now let’s see how we can configure them. As this is something you have to do for all your projects and for all the different PICs you might use, Microchip has tried to make it easier for you. I know when I first started writing programs for PICs it wasn’t quite as easy as it is now.
To write the code for the configuration words, we use a special window in the MPLABX IDE. To open this window, click the word window
on the main menu bar and then select Target Memory Views
from the drop-down menu that appears. Then select configuration bits
from the slide-out menu that appears. This process is shown in Figure 1-8.
Figure 1-8
Opening up the configuration bits
Once you have selected the configuration bits option, your main window will change to that shown in Figure 1-9.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig9_HTML.jpgFigure 1-9
The configuration bits
As this is the PIC16F88, there are not that many settings for us to consider. The first one listed is the main one we need to change. It is labeled FOSC (for frequency of oscillator). The default setting is usually the external RC oscillator. You should see under the setting
label that it indicates that it is connected to RA6. This means that the pin RA6 (i.e., bit6 of PORTA) cannot be used for anything else, as it is used to take the signal from the external RC oscillator into the PIC.
I always prefer to use the internal oscillator block because it saves the cost of the external oscillator and it frees up pin RA6 and more, as we will see. To change this setting, we must click the mouse on the small arrow at the side of the phrase EXTRCCLK
and select the option INTOSCIO
, which means the internal oscillator with input/output function on pins RA6 and RA7. You should see that the comments under the label setting
have changed to show this and they are shown in blue.
We will make two other changes:
WDTE: We will turn it off. The WDTE is a watch dog timer enable that, if enabled, will stop the program if nothing happens for a set period of time (usually a short period of time). This is really a safety factor that is used in industry, whereby on a production line if nothing happens for any length of time, it means something has gone wrong so we should stop production and find out what has gone wrong. Well, most of our programs won’t need that safeguard so we should turn it off. I think this aspect of the WDT shows that the Arduino is not really meant for industry, as again this option has already been taken out of your hands.
The third item to change is the LVP. We should turn it off so that bit3 of PORTB is left as a normal input output pin.
Those are the changes that we need to make for this PIC, and these changes are shown in Figure 1-10.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig10_HTML.jpgFigure 1-10
The changes to the configuration words
All we need to do now is generate the source code and use it in our program. This process is a lot easier than it has been, because all we need to do now is click the tab Generate Source Code to Output
and MPLABX will do it for us. This tab is at the bottom of the screen as shown in Figure 1-9 and Figure 1-10. Once you generate the code, it should appear as shown in Figure 1-11. You may have to minimize the configuration bits window to show the source code better.
Figure 1-11
The config bits source
What we are going to do is copy these instructions and paste them into a header file. We could paste them into the program listing that we will use for the first program. However, we will not start writing that program until we get to chapter 2. Also I want you to understand that when we write our other programs for the 16F88, we will use the same configuration words. There may be times when we want to use a different set of configuration words, but that won’t happen in the programs in this book. Therefore, to remove the need to repeat the process of writing the same configuration words in all our other PIC16F88 projects, we will save these instructions to a header file: first a local header file and then a global header file.
Creating a Header File
The process of creating a header file is quite simple and yet very useful. First, in the main editing window, you need to right-click the mouse on the phrase Header Files
in the project tree. Then select New
and then the xc8_header,h..
option from the fly-out menu that appears. This is shown in Figure 1-12.
Figure 1-12
Creating the new header file
You will be asked to give the file a name. I have suggested pic16F88ConfigSettings
as shown in Figure 1-13.
Figure 1-13
Naming the new header file
Once you are happy with the name of the file, click Finish
, and the main editing window should change to show the new file open and ready for editing. This is shown in Figure 1-14.
Figure 1-14
The header file in the main editing window
You will see that Microchip automatically inserts an awful lot of text into the file. I have never used any of it and I simply delete it all. To ensure that your windows look exactly as I expect them to, I would like you to delete all that text; thank you.
Before we copy the instructions for the configuration words into this file, we should add some comments. It is good practice to include comments in all your programs. You know what you are doing now but in six months or less, you will wonder why you did what you have done; therefore, always add comments.
There are two types of comments in ‘C’ programs:
Single-line comments, which start with two forward slashes as shown here //. Anything on the same line after the two forward slashes is ignored by the compiler, as they are simply comments. For example: //these words are just comments.
Multiple lines of comments or a paragraph of comments. These are text inserted between the following symbols /* */. For example:
/* Your comments are written in here */
Your comments should have the following content at least:
Who wrote it (i.e., you)
What PIC you wrote it for and when you wrote it
What you are trying to do with it
As a suggestion you should add the following paragraph of comments:
/*Configuration words for the PIC16F88
Using the internal oscillator block
Turning the WDT off and the LVP off.
Written by Mr. H. H. Ward dated 22/02/2021*/
These should go at the top of the empty file.
Obviously you should insert your name and the appropriate date.
Now we need to get back the configuration bits we created before. There should be a tab on the bottom left of the screen with the words configuration bits
. If you click the mouse on that tab, the window should appear in the editing screen. You now need to click the mouse on Generate Source Code to Output
to create the source code. The source code may not automatically appear and you may have to click the mouse on an empty area of the header file to bring them into view. When you have them in view, I want you to copy everything EXCEPT the last phrase, which is #include
Your editing window should now look like that shown in Figure 1-15.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig15_HTML.jpgFigure 1-15
The source code pasted into the header file
All we have to do now is save the file using the save option under the word file
on the main menu bar.
So now we have created a local header file
. We will look at how we can use this and other header files in chapter 2. I want to explain why I am calling it a local header file and why we need to make it a global header file
. A local header file is one that can only be used in the current project you have created it in. It is used to split your project up into small sections so that a group of programmers may work on the different sections. However, it does not fit our purpose as it stands at present. We want to create a header file that we can use in all our projects that used the same configuration words. To do that, we must change this local header file into a global header file, which is one we can use in all our projects that use the same configuration words. At present, this header file is saved in the directory for this project, and therefore only this project will find the file. What we need to do is save a copy of this file in a place where all projects will find it. This will be the include
folder of the XC8 compiler software we are using within MPLABX. If you are using more than one compiler version, then you must save a copy in the include
folder for all the compiler versions you may use. This folder will most likely be in the Microchip directory that was created when you installed MPLABX. The path to the include
folder I will copy this file into is shown here:
C:\Program Files (x86)\Microchip\xc8\v1.35\include
You will have to find the header file you have just created and the path to find it on my laptop (Figure 1-16).
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig16_HTML.jpgFigure 1-16
The first16F88Sim folder and header file
You should remember that I said when you create a project in MPLABX, the software will create a folder on your system where it will store all the files for your project.
Once you have found the include
folder of the compiler software you use, you can paste a copy of the header file you have just created into the folder. By creating a copy of the header file, you will get a global header file that will be available for all our future projects that use the same configuration settings. What happens in the other projects, where you have asked to have the header file included, is that the linker program will go to the include folder in the compiler software and find the header file you want to use.
We will look at this more closely when we write our first program in chapter 2.
Changing the Fonts and Colors
You will notice that I have changed the color of my comments to black and bold, size 14. This is to try and make them more visible than the default gray.
If you want to change the color, you can do so by selecting the word options
from the drop-down menu that appears when you select the tools
and the options choice from the main menu bar. You will get the window shown in Figure 1-17.
Figure 1-17
Changing the font and colors
You should click the tag for fonts and colors. Then select what you want to change. Once you are happy with your choice, click OK
. I have selected the fonts and colors and then changed the color of the comments to black, as shown in Figure 1-17.
The PIC Microcontroller
Just before we finish this first chapter, I think it might be useful to discuss what a PIC is. Some people say it stands for programmable industrial controllers, or programmable intelligent controller, or programmable interface controller. However, some say it is really just a trademark for the microcontrollers produced by Microchip. The term PIC is used by Microchip to cover an extremely wide range of microcontrollers produced by them. I will simply refer to the microcontroller as the PIC.
Each PIC will have all the components of a microprocessor-based system as shown in Figure 1-18, such as the following:
a microprocessor
ROM, RAM
an I/O chip
the associated address, data, and control buses.
However, all these parts are all on a single chip, not several chips, as with older microprocessor-based systems. This means it is really a single-chip computer.
As well as all that, the PIC has much more circuitry on the single chip. This extra circuitry is used to make it into a control system with a micro at the heart of it. The extra circuit may include an ADC (analog-to-digital converter ), opamp circuits for compare and capture, a PWM module, and a UART module. These extra circuits may not be on all PICs as PICs vary in their makeup for different applications.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig18_HTML.jpgFigure 1-18
The basic microprocessor system
One more thing before we move on is that the PIC is a RISC chip as opposed to a CISC chip. RISC stands for reduced instruction set chip, whereas CISC stands for complex instruction set chip. Indeed, the instruction sets for PIC micros range from 35 to 75 core instructions. However, the 18F4525 has an extended instruction set at your disposal. The Intel processor, which is a CISC chip, uses hundreds of instructions, so the PIC is pretty efficient.
The PIC16F88 and the PIC8F4525
This book is based around using these two PICs. They are both eight-bit micros, which basically means they have an eight-bit data bus and so take data in chunks of eight bits, which is referred to as a byte. Microchip also produces PICs that are 16 bits, 24 bits, and 32 bits. Modern PCs use 64-bit processors now. However, you shouldn’t think that these two PICs are old hat and that what you will learn in this book is out of date. First, these two PICs, especially the PIC18F4525, can perform a wide range of control functions, as you will find out. It is quite easy to build control boards with them on simple vero boards, as they come in 18-pin, 20-pin, and 40-pin dual inline (DIL) chips. I have used the 32-bit PICs from Microchip and they are 100-pin surface mount devices. The fact that these two eight-bit PICs come in DIL packages does make them easy to use and to make prototype boards with them. When I build my circuit boards, I use the 18 pin, 20-pin, or 40-pin IC sockets so that I don’t have to solder the actual PICs to my circuits. Also, the ‘C’ language you will learn in this book is the same ‘C’ language you will use on the 32-bit PICs.
Figures 1-19 and 1-20 show the two PICs we are using. As you grow in confidence with using these PICs, it will be useful if you downloaded a copy of the data sheets for the PICs. These can be found on the Microchip web site. Indeed, as you develop your experience in electronics, you will need to keep a copy of the datasheet for any device you use. I must have hundreds of datasheets that I use in all my work.
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig19_HTML.jpgFigure 1-19
The PIC16F88
../images/512435_1_En_1_Chapter/512435_1_En_1_Fig20_HTML.jpgFigure 1-20
The PIC18F4525
Summary
In this chapter, we have learned what an IDE is and how to create a project within MPLABX, the IDE from Microchip. We have looked at the importance of header files, and the difference between local and global header files. We will go on to create our own header files for functions that we will use in exactly the same way in most of our programs as the book progresses. We have also looked at what a PIC is and the two PICs we will be using in this book.
In the next chapter, we will create our first program and learn how to use the header file we have just created, and other header files, in it. We will also start our analysis of ‘C’ programs as to how a ‘C’ program works and how the instructions of the ‘C’ program operate. I hope you will enjoy reading this book and learn a lot from it. Good luck and happy reading.
© The Author(s), under exclusive license to APress Media, LLC, part of Springer Nature 2022
H. H. WardProgramming Arduino Projects with the PIC Microcontrollerhttps://doi.org/10.1007/978-1-4842-7230-5_2
2. Programming Basics
Hubert Henry Ward¹
(1)
Leigh, UK
This chapter covers the following main topics:
A standard approach to writing a program
How to create a source file within a project
How to use the header file into source file
How to set up different types of oscillators
How PIC communicates with the outside world using PORTS
How to use TRIS registers to set the PORTS
The main aspects of a ‘C’ program
How to download a program to a development board
It also looks at how you might build your own development board and use ICSP (in-circuit serial programming). However, you should be fairly confident with building circuits on vero boards. After reading this chapter, you should be able to create a project and write a program that can be run on a development board.
Good Programming Practice
You have an idea of what you want to do and you can’t wait to start writing code. However, you cannot rush things; there is just too much to consider and too many things you can miss if you don’t plan your work first. You need to consider which PIC you will use: there are so many different PICs, from the simplest 8-pin device to ones with 100 pins. You will most likely find a PIC that will do all you want and then stick with that one; however, you should really learn to be adaptive.
The very least you should do is to write down a plan of how you are going to solve the problem you are faced with. Will you need a lot of I/O pins (input/output pins)? Will you need an ADC (analog-to-digital converter)? This will depend upon whether or not you will need any analog inputs, or if you with just use digital inputs and outputs. Your written plan should answer all these questions, and more, then help you decide what PIC you will use.
Algorithms
This is really a posh word for your written plan. It is really simply putting your thoughts of how you are going to get the PIC to do what is asked of it down on paper. The algorithm should cover at least the following:
You should explain the sequence of events you want to control.
You should then identify all the input and output devices you will need.
You should then create an allocation list for the I/O and identify any special inputs or outputs or controls you will need, such as analog inputs, PWM outputs, and any timers.
The algorithm should ideally break the process down to questions that have one of two possible answers (i.e., pure logical questions). This is why we use the binary number system to represent logic, as it is a number system that has only two digits: 0 and 1.
Flowcharts
Flowcharts are diagrams that show how any process flows through its constituent parts. They are very useful diagrams for designing computer programs. All flowcharts use four basic symbols; there are more but the four most common symbols are shown in Figure 2-1.
../images/512435_1_En_2_Chapter/512435_1_En_2_Fig1_HTML.jpgFigure 2-1
The main flowchart symbols
Program Listings
This is a list of the actual instructions written in your chosen language. It should be the last thing you do; but as you become more experienced, you will tend to do this after you have written your algorithm, leaving flowcharts only for the most intricate parts of your program. You can decide which approach is best for you.
If you have constructed your flowchart correctly, then each block in your flowchart will produce the correct lines of coding in your program listing.
Program 2.1: Turning On and Off an LED
In Program 2.1 we will learn about the inputs to the PIC to control an output of the PIC. We will use a start switch to turn an LED on and a stop switch to turn it off. The circuit for the project is shown in Figure 2-2.
../images/512435_1_En_2_Chapter/512435_1_En_2_Fig2_HTML.jpgFigure 2-2
The minimal circuit diagram for Program 2.1
Now we are ready to get down to the real part of this process, writing the code for the program. First we will start with the algorithm.
Algorithm for Program 2.1
The sequence of events is as follows.
1.
The PIC will wait for the momentary switch, the start button, to be pressed (i.e., go to 0V, a logic ‘0’). Being a momentary switch, it will go back to 5V, a logic ‘1’, automatically.
2.
The PIC will then turn the LED on.
3.
The PIC will then wait until the stop switch is pressed, in the same way as the start switch.
4.
The PIC will then turn the LED off.
5.
The program will loop back to the beginning where it waits for the start switch to be pressed.
6.
The program will require two inputs: one for each switch and one output for the LED.
7.
The start switch will be allocated to bit0 of PORTA and the stop switch will be allocated to bit1 of PORTA.
8.
The LED will be allocated to bit0 of PORTB.
9.
There will be no need for any analog inputs and so no ADC.
10.
To save I/O, we will use the internal oscillator block of the PIC.
I have included the last two items in the algorithm to try and show you that a good algorithm can help you choose what PIC you need for your project. There are a lot of PICs to choose from and they have different capabilities. However, you will most likely settle down to using your favorite PIC as you gain more experience. In this book, we have already chosen the PICs we will use.
Flowchart for Program 2.1
The flowchart for Program 2.1 is shown in Figure 2-3. If the flowchart is complete enough, then every block in the flowchart should relate to a section of instructions in the program listing.
../images/512435_1_En_2_Chapter/512435_1_En_2_Fig3_HTML.jpgFigure 2-3
The flowchart for Program 2.1
The Program Listing
I will assume you have never written a C program before. It is not essential that you understand C programming, as I will carry out a line-by-line analysis of the instructions in the listings that should help explain how a C program works. The only thing you should appreciate is that a C program works in a series of loops. The PIC will carry out the instructions in those loops sequentially one at a time unless the programmer forces the PIC to move out of that sequence. When the PIC comes to the last instruction in the loop, the PIC will go back to the beginning of the loop and start again. A C program must have at least one loop: the "main" loop. The micro will go to this main loop to find the first instruction of the program. We will discuss the importance of this main loop when we go through the analysis of Listing 2-1.
I hope that by reading my analysis of these program listings, you will not only learn what a C program is but how the instructions work and do what we want them to. Program 2.1, the program we will look at, is quite simple.
We will use the header file for the configuration words that we created in chapter 1. This means we will need to include the header file into our source code file. However, to do that we need to create the source file from within the project we created in chapter 1.
Creating a Source File
The source file is where we will write and store the instructions for the program. We could simply write every bit of code we need for the program inside this one file. However, that is not really good practice, even though there is nothing really wrong with it except that it could mean you writing the same code over and over again. A better approach would be to use header files—which we will look at as we progress with the book—but header files you have written, not someone else. Indeed, when programming the Arduino, you will use a whole range of header files. However, with the Arduino, that is done to make your work in writing programs for the Arduino much less arduous, as these header files have already been written for you. In my opinion, it does far too much for you. I know when I have programmed the Arduino it is easy to get it to do what you want, but you are left not really understanding how it does it and you have not learned much if anything at all. I firmly believe that a good programmer should know exactly how all the code they write works. They should be able to write all the code they use themselves, even the header files they use, not rely on header files that someone else has written for you. It is my main aim that, after reading this book, you will become a programmer who understands all the code they write and use.
Program 2.1 is written for the PIC16F88. The first few programs will be written for that PIC. This means that we could be writing the same configuration words for the next few programs. However, instead of doing that, we are going to use the header file we created in chapter 1, as we will be using the same setting for these programs.
Assume we have the MPLABX software open with the project we created in a chapter 1 open. If it is not open (i.e., it is not in the project tree window), then you can select the word file
from the main menu bar. Then select Open Recent Project
and you should see the project title appear in the fly-out window. Once you have selected or opened the project, the software should look like that shown in Figure 2-4.
Figure 2-4
The editing window with the project opened
If the project tree is minimized in the project window (i.e., not shown), then you need to click the ‘+’ sign in the small square next to the gray folder box alongside the project title ourFirst16F88
. This should open up the tree. If the project window is not visible, then you will have to click the word window
on the main menu bar and select the orange project option for the drop-down menu that appears.
Once you have got the editing window open and the project tree on view, you need to right-click the mouse on the phrase Source Files
then select New
and then main C
from the fly-out menus that appear. This is shown in Figure 2-5.
Figure 2-5
The new main c source file menu
Having done that, you will be presented with the name and location window. I tend to give my source files the same name as the project but with the addition of Prog
. This is shown in Figure 2-6.
Figure 2-6
The name and location window
I always accept the default location, which is the folder that the software created when we created the project. There is no need to add the extension, as the software will give the file the required ‘c’ extension as shown in Figure 2-6.
Once you are happy with the name and location, simply click Finish
. The window will close and the main editing window will change to show the file we have just created open ready for you to add your instructions.
If you still have a tab with the start-up page evident in the editing window (it may not be the top tab), you can close the tab by clicking the mouse on the small square with the ‘x’ in it associated with that tab.
Microchip automatically inserts a paragraph of comments and the main loop, which must be in the C program, along with an include statement. I see no point in adding the word void
inside the two normal brackets, and I like to have my opening and closing curly brackets on their own separate line. I will explain these changes when we start to look at the program listing. I would, however, like you to make the same changes so that our screens do look the same. This is shown in Figure 2-7.
Figure 2-7
The source file opened in the editing window
Adding the Header File
There are two ways of adding the header file we want, because it has been created in the project, which means it is local to the project. However, we should have copied it into the include directory of the compiler software, which means it is globally available to any project we want to use it in. Firstly, we will add it as a local header file. To do this, move the mouse to the beginning of line 8 (i.e., the next line after the paragraph of comments), and place the insertion point there. Now type in the hash key ‘#’. As you type this symbol, the intellisense
of the compiler software takes over. This is a bit like predictive text on your mobile phone. The compiler tries to guess what it is you are going to type next. The software presents you with a drop-down menu that shows a list of possible directives, shown in green, that you may want to use. The one we want is include
, shown at the bottom of the list. You can simply click the mouse on that word or type include
, without the quotation marks, into the file. When you finish either inserting or typing the word include
, if you press the spacebar a small window should appear showing the local header files we have available to us. The one we want should be visible, as shown in Figure 2-8.
Figure 2-8
The intellisense displaying the local header file
If it is visible, then you can click the mouse on the file name and it should be inserted in the file. If it is not visible, then you may have to type the name in as shown here:
pic16F88ConfigSettings.h
.
Note that you will have to include the quotation marks and the .h. The quotation marks tells the compiler software it is a local header file. When you have typed it in correctly, the screen should look like that shown in Figure 2-9.
../images/512435_1_En_2_Chapter/512435_1_En_2_Fig9_HTML.jpgFigure 2-9
The local header file included
Note that the text uses different colors to show the different uses: keywords are in blue, key directives are in green, and so on. This is because this is more than