Industrial Security System Using Microcontroller Regulated Power Supply

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 6

INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

REGULATED POWER SUPPLY

A variable regulated power supply, also called a variable bench power


supply, is one where you can continuously adjust the output voltage to
your requirements. Varying the output of the power supply is the
recommended way to test a project after having double checked parts
placement against circuit drawings and the parts placement guide.

This type of regulation is ideal for having a simple variable bench power
supply. Actually this is quite important because one of the first projects a
hobbyist should undertake is the construction of a variable regulated
power supply. While a dedicated supply is quite handy e.g. 5V or 12V, it's
much handier to have a variable supply on hand, especially for testing.

Most digital logic circuits and processors need a 5 volt power supply. To
use these parts we need to build a regulated 5 volt source. Usually you
start with an unregulated power To make a 5 volt power supply, we use a
LM7805 voltage regulator IC (Integrated Circuit). The IC is shown below.

The LM7805 is simple to use. You simply


connect the positive lead of your unregulated DC power supply (anything
from 9VDC to 24VDC) to the Input pin, connect the negative lead to the
Common pin and then when you turn on the power, you get a 5 volt
supply from the Output pin.

CMR INSTITUTE OF TECHNOLOGY P a g e | 31


INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

PROGRAMMING ALGORITHM

Before programming the AT89S52, the address, data, and control signals
should be set up according to the “Flash Programming Modes” (Table 22-1) and
Figure 22-1 and Figure 22-2. To program the AT89S52, take the following
steps: 1. Input the desired memory location on the address lines. 2. Input the
appropriate data byte on the data lines. 3. Activate the correct combination of
control signals. 4. Raise EA/VPP to 12V. 5. Pulse ALE/PROG once to program
a byte in the Flash array or the lock bits. The byte-write cycle is self-timed and
typically takes no more than 50 μs. Repeat steps 1 through 5, changing the
address and data for the entire array or until the end of the object file is
reached.

Data Polling:

The AT89S52 features Data Polling to indicate the end of a byte write cycle.
Dur-ing a write cycle, an attempted read of the last byte written will result in
the complement of the written data on P0.7. Once the write cycle has been
completed, true data is valid on all outputs, and the next cycle may begin. Data
Polling may begin any time after a write cycle has been initiated.

Ready/Busy:

The progress of byte programming can also be monitored by the RDY/BSY


output signal. P3.0 is pulled low after ALE goes high during programming to
indicate BUSY. P3.0 is pulled high again when programming is done to indicate
READY.

Program Verify:

If lock bits LB1 and LB2 have not been programmed, the programmed code
data can be read back via the address and data lines for verification.

CMR INSTITUTE OF TECHNOLOGY P a g e | 32


INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

The status of the individ-ual lock bits can be verified directly by reading them
back. Reading the Signature Bytes:

The signature bytes are read by the same procedure as a nor-mal verification
of locations 000H, 100H, and 200H, except that P3.6 and P3.7 must be pulled
to a logic low. The values returned are as follows. (000H) = 1EH indicates
manufactured by Atmel (100H) = 52H indicates AT89S52 (200H) = 06H

Chip Erase:

In the parallel programming mode, a chip erase operation is initiated by using


the proper combination of control signals and by pulsing ALE/PROG low for a
duration of 200 ns - 500 ns. In the serial programming mode, a chip erase
operation is initiated by issuing the Chip Erase instruction. In this mode, chip
erase is self-timed and takes about 500 ms. During chip erase, a serial read
from any address location will return 00H at the data output.

Programming the Flash – Serial Mode The Code memory array can be
programmed using the serial ISP interface while RST is pulled to VCC. The
serial interface consists of pins SCK, MOSI (input) and MISO (output). After
RST is set high, the Programming Enable instruction needs to be executed first
before other operations can be executed. Before a reprogramming sequence can
occur, a Chip Erase operation is required. The Chip Erase operation turns the
content of every memory location in the Code array into FFH. Either an
external system clock can be supplied at pin XTAL1 or a crystal needs to be
connected across pins XTAL1 and XTAL2. The maximum serial clock (SCK)
frequency should be less than 1/16 of the crystal frequency. With a 33 MHz
oscillator clock, the maximum SCK frequency is 2 MHz.

CMR INSTITUTE OF TECHNOLOGY P a g e | 33


INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

Serial Programming Algorithm

To program and verify the AT89S52 in the serial programming mode, the
following sequence is recommended: 1. Power-up sequence: a. Apply power
between VCC and GND pins. b. Set RST pin to “H”. If a crystal is not connected
across pins XTAL1 and XTAL2, apply a 3 MHz to 33 MHz clock to XTAL1 pin
and wait for at least 10 milliseconds. 2. Enable serial programming by sending
the Programming Enable serial instruction to pin MOSI/P1.5. The frequency of
the shift clock supplied at pin SCK/P1.7 needs to be less than the CPU clock at
XTAL1 divided by 16. 3. The Code array is programmed one byte at a time in
either the Byte or Page mode. The write cycle is self-timed and typically takes
less than 0.5 ms at 5V. 4. Any memory location can be verified by using the
Read instruction which returns the content at the selected address at serial
output MISO/P1.6. 5. At the end of a programming session, RST can be set low
to commence normal device operation. Power-off sequence (if needed ): 1. Set
XTAL1 to “L” (if a crystal is not used). 2. Set RST to “L”. 3. Turn VCC power off.

Data Polling:

The Data Polling feature is also available in the serial mode. In this mode,
during a write cycle an attempted read of the last byte written will result in the
complement of the MSB of the serial output byte on MISO.

CMR INSTITUTE OF TECHNOLOGY P a g e | 34


INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

MICROCONTROLLER VERSUS MICROPROCESSOR

What is the difference between a Microprocessor and Microcontroller? By


microprocessor is meant the general purpose Microprocessors such as Intel's
X86 family (8086, 80286, 80386, 80486, and the Pentium) or Motorola's 680X0
family (68000, 68010, 68020, 68030, 68040, etc). These microprocessors
contain no RAM, no ROM, and no I/O ports on the chip itself. For this reason,
they are commonly referred to as general-purpose Microprocessors.

A system designer using a general-purpose microprocessor such as the


Pentium or the 68040 must add RAM, ROM, I/O ports, and timers externally to
make them functional. Although the addition of external RAM, ROM, and I/O
ports makes these systems bulkier and much more expensive, they have the
advantage of versatility such that the designer can decide on the amount of
RAM, ROM and I/O ports needed to fit the task at hand. This is not the case
with Microcontrollers.

A Microcontroller has a CPU (a microprocessor) in addition to a fixed


amount of RAM, ROM, I/O ports, and a timer all on a single chip. In other
words, the processor, the RAM, ROM, I/O ports and the timer are all embedded
together on one chip; therefore, the designer cannot add any external memory,
I/O ports, or timer to it. The fixed amount of on-chip ROM, RAM, and number
of I/O ports in Microcontrollers makes them ideal for many applications in
which cost and space are critical.

In many applications, for example a TV remote control, there is no need


for the computing power of a 486 or even an 8086 microprocessor. These
applications most often require some I/O operations to read signals and turn
on and off certain bits.

CMR INSTITUTE OF TECHNOLOGY P a g e | 35


INDUSTRIAL SECURITY SYSTEM USING MICROCONTROLLER

MICROCONTROLLERS FOR EMBEDDED SYSTEMS

In the Literature discussing microprocessors, we often see the term


Embedded System. Microprocessors and Microcontrollers are widely used in
embedded system products. An embedded system product uses a
microprocessor (or Microcontroller) to do one task only. A printer is an example
of embedded system since the processor inside it performs one task only;
namely getting the data and printing it. Contrast this with a Pentium based PC.
A PC can be used for any number of applications such as word processor,
print-server, bank teller terminal, Video game, network server, or Internet
terminal. Software for a variety of applications can be loaded and run. Of
course the reason a pc can perform myriad tasks is that it has RAM memory
and an operating system that loads the application software into RAM memory
and lets the CPU run it.

In an Embedded system, there is only one application software that is


typically burned into ROM. An x86 PC contains or is connected to various
embedded products such as keyboard, printer, modem, disk controller, sound
card, CD-ROM drives, mouse, and so on. Each one of these peripherals has a
Microcontroller inside it that performs only one task. For example, inside every
mouse there is a Microcontroller to perform the task of finding the mouse
position and sending it to the PC. Table 1-1 lists some embedded products.

CMR INSTITUTE OF TECHNOLOGY P a g e | 36

You might also like