# Data link

The data link forms the communications channel between the main control unit and individual appliance controllers and sensors throughout the house. Of the many possible ways this could be achieved (radio, infra-red, wires, etc.) the neatest method is through the mains wiring system, as devices being controlled are likely to use the mains as their source of power and so do not need another connection.

There is an established mains based control system called X10, but this is only designed for 110V 60Hz North American mains systems, not for European 220/240V 50Hz mains. Therefore it is not possible to produce a compatible system for European use.

The obvious problem with using mains is that there is a high current high voltage 50Hz frequency already present, so the data link has to be kept separate to prevent interference between the two signals. To do this, the most reliable way is to modulate any signal with a high frequency carrier, so that the 50Hz mains signal can be filtered out by the receiving circuit, leaving the high frequency carrier with the data modulated on it. Because of the potential dangers of using the mains directly, all the circuits were tested using a transformed down mains voltage. This was achieved using a standard transformer mounted in a sealed metal box with taps at 2, 4, 6, 8, 10 and 12V RMS. In a production system, this would either be the main power transformer for the appliance, or an additional auxiliary transformer.

There are dedicated ICs which will contain the entire transmission and receiving system, but these cannot be used here because they require a direct connection to the mains, so cannot be used with a step-down transformer.

A block diagram of the data link is shown below:



This would be repeated twice to provide a two-way (duplex) communications channel, with the same transmission line being used.

Initially only one channel was constructed to evaluate the systems being used. The receiving electronics depends on the transmitting electronics and the signal being transmitted, so the transmitting circuit was considered first.

## Transmission

In the first instance, the following amplitude modulator (a Colpitts oscillator) was tried for the transmission system:



When this was first built, it behaved erratically, and would not oscillate properly. At first I thought this was down to the transistor, because a lack of BC107s meant a BC109 had to be used. These two transistors are similar in most respects, but they may have been operating at the limits of their specification. Examining a data book showed that the guaranteed minimum frequency a BC107 or BC109 could switch at was 150 MHz, greatly in excess of even any upper sidebands being generated here. Replacing the transistor for one from another batch or another manufacturer had no effect, ruling out the transistor as the problem.

As the components were fairly close together on the breadboard, I wondered whether the capacitance of the board was having an effect. This capacitance is only slightly smaller than the 100pF capacitor being used, so it may have had an effect on it. To test this, the circuit was rebuilt spaced further apart on the board, using the same components. This did work, giving a steady output waveform reasonably close to a sine wave when given a +15V supply rail. When the supply rail was lowered, the amplitude of the output fell, but the frequency did not change noticeably.

The modulating properties of this circuit were tested by feeding it a digital square wave between 0 and 5V. The resulting bursts of sine wave showed that the output was being modulated properly. When the frequency of the modulated input was increased to around 100 kHz, the oscilloscope showed that the modulated output was taking a few microseconds to start up, so the spaces between pulses of the output increased, reducing its mark/space ratio.

| Modulatin<br>signal | g |  |
|---------------------|---|--|
| Output<br>signal    |   |  |

This would give an upper limit on the bandwidth that could be used, but as the control information consists of only a few bytes, only a small bandwidth is required.

The problem with the system as it stands is that it has a very small power output, as any load will affect its oscillation. A high power amplifier is required to boost the signal into a form suitable for mains transmission. This was tried using a push-pull output stage as shown below:



When this was connected, there was very little output at all. The transistor data book states that the maximum frequency of these transistors is 50MHz. However, this circuit is primarily designed for audio signals, so its gain may be severely reduced for such high frequency applications. The problem with using high frequency transistors is that they can supply a relatively small current – of the transistors it was possible to obtain, the 2N4427 had the highest collector current of 500mA at up to 500MHz. A semiconductor manufacturer's catalogue showed that even solid gold cased microwave transistors designed for the military could only supply 120mA. These are small compared to the 2A the BC441 and BC461 pair can supply at audio frequencies.

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

Although there was a very small output, the push-pull output stage was connected to a 8V AC transformer output to see if this affected the oscillator in any way. It certainly did, causing the AC signal to leak into the oscillator so that large AC signals were present throughout. This overwhelmed the small signals making it oscillate so that it was not possible to detect any 1MHz signal at all. The reason for this leakage is that bipolar transistors are being used. When the transistor is turned on, there is 0.7V across the base-emitter junction. If 11.3V (peak voltage of 8V RMS) suddenly appears at the emitter of the NPN transistor, the base will rise to 12V. Thus the AC signal will leak through the transistor with only a small amount of crossover distortion. This signal will now be present at the collector of the BC109 in the Colpitts oscillator, and so will leak through into the oscillator, preventing it from working.

There are two alternatives to prevent this problem, either filter out the sine wave or use a MOSFET, which does not suffer from the problem of the AC leaking through it. The problem with a MOSFET is that the maximum frequency is very close to that being passed through it, so problems may occur. The alternative, filtering out the 50Hz sine wave, is a better choice. This filter has to be designed so that it can filter out the 50Hz entering in one direction, while allowing the high frequency carrier to pass through in the other direction. Any active device connected directly to the output might suffer similar problems to the bipolar transistor above, so a passive filter is needed.

The problem with amplitude modulation is that it is very susceptible to noise. In a system such as the one above, very narrow bandpass filters would be required to minimise any noise from being detected as a signal. As the signal is AM, transmission factors, such as reflection caused by plugging in a new appliance to the ring main, could modify the amplitude of the signal and so generate spurious digital outputs.



To prevent these problems, a 150 kHz frequency modulator from *Electronic Systems* was tried: +15V

As the 741's output had a swing of  $\pm 13V$ , the CMOS logic was powered from  $\pm 15V$ .

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

When this circuit was tried, a number of problems arose. Firstly, it was very reluctant to start oscillating. The power-on reset system composed of the 100nF capacitor and 10K resistor appeared to drop the reset signal before the components had settled down, so the system did not always start when power was applied. The situation was improved by replacing the 100nF capacitor with a 10 $\mu$ F value. This meant that there was a short delay before the system started oscillating, but it appeared to be more reliable.

Another problem appeared to be that the system would sometimes stop oscillating for no apparent reason. The only way to restart it was to momentarily short the  $10\mu$ F capacitor, effectively performing a power-on reset. An oscilloscope showed that there was a significant amount of noise on the power supply rails. Inserting large numbers of decoupling capacitors across the supply reduced this, but the unreliability persisted. One possible explanation for it is that if a momentary drop in the power supply coincided with a high level on one of the input pins, perhaps generated by the voltage across a capacitor, then the input would be at a higher voltage than the power supply. It is known problem that if the input or output of a CMOS gate is driven beyond the supply, it will go into a state known as 'SCR latchup', where two transistors in a push-pull formation will both turn on, effectively shorting the power supply. This would result in the chip getting hot and burning itself out, but in this case the supply will still be fluctuating and will clear this problem. While this is happening the logic output of the gate could be anything, and so the circuit is quite likely to stop oscillating.

The obvious alternative is to replace the CMOS logic gates with another family. The problem is that the 4000 series is the only family which can handle power supplies above +7V. Reducing the voltage to this, or to the standard TTL level of +5V would severely limit the range of output frequencies.

When the circuit did work, it produced a reasonable square wave which did vary with the input voltage. However, it was not possible to see how rapidly the output was changing. If a square wave were input into the system, there would be a period after the edge of the square wave where the output would gradually rise or fall in frequency. The assembled circuit would not oscillate for long enough to be able to measure this, but the diagram below shows what should happen:



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

This would cause problems at the decoding end. The other problem with this circuit is that it requires a wider bandpass filter at the receiving end. This creates a larger frequency window which noise can pass through. In radio systems, the noise factor comes from factors involving the electromagnetic wave, such as diffraction and destructive interference. In a mains transmission system, these may be present, but also present are sources which generate a regular frequency of noise, such as motors or equipment containing electronic oscillators which leak into the mains. In most of these applications the fundamental frequency will be much lower than the high frequency used for transmission, but higher harmonics of the noise frequency may fall within the transmission band.

A frequency shift keyed modulator would overcome many of these problems, as the receiving circuit only needs to deal with two specific frequencies. Unfortunately, the only FSK modulator circuits I could find were essentially digital in nature, and designed for generating tones for sending down a telephone line or storing on cassette tape. This uses a 1.2 kHz signal to represent a 0 and a 2.4 kHz signal to represent a 1. Using these frequencies directly with the mains would be very susceptible to noise, and may cause electrical appliances to resonate audibly at these frequencies. The problem with using two frequencies is that the attenuation caused by the mains may be a function of the frequency. Therefore one frequency may have a greater amplitude than the other when they are received. This means some kind of automatic gain control is required. The AGC would have to be designed very carefully to ensure that both emerge at the same amplitude, but if there is no signal present the AGC would also have to adjust itself to take into account changes in signal amplitude caused by the plugging and unplugging of electrical appliances, which would affect the properties of the transmission line.

Some of these problems can be overcome if very tight timing is used on the digital signal. This method is similar in principle to Morse code, where the length of a pulse is used to determine its logic state. If a pulse is detected which has a duration not recognised as either of the two logic states, it can be ignored, providing significant noise immunity. This means one frequency can used, which simplifies the electronics immensely.

To test this, a derivative of the oscillator above was used, this time using TTL NOR gates, as the oscillator here is a fully digital system:



This was intended to produce a 500 kHz square wave. This was tested, and did produce a good square wave.

### **Transmission filtering**

This square wave cannot be sent through the mains directly, as if there was a signal being sent at a higher frequency, the higher harmonics of the 500 kHz square wave might interfere with it. The square wave therefore needs to be converted to a sine wave to minimise interference, and the simplest way to do this is to filter off the higher harmonics. If a passive filter is used, it can also form the filter which prevents the mains waveform interfering with the output driver from the oscillator.

This application needs a reasonably sharp bandpass filter to filter out the 50 Hz mains frequency, as well as any mains-borne noise. The best passive filter that will perform this function is a series LC network, as shown below, as it has a small bandwidth. There is an additional benefit, as the filter has a low output impedance, a desirable property for the output.



To compensate for component tolerances, the filter must be adjustable. A variable capacitor is easier to use than a variable inductor, so this can be used as the tuning component. The highest value that was to hand was a 0-125pF AM tuning capacitor, which therefore determines the inductor to be used. At 500 kHz:

$$f_{0} = \frac{1}{2\pi\sqrt{LC}}$$

$$\sqrt{LC} = \frac{1}{f_{0}^{2}\pi}$$

$$L = \frac{1}{4\pi^{2}Cf_{0}^{2}}$$

$$L = \frac{1}{4\pi^{2}.125 \times 10^{-12}.(500 \times 10^{3})^{2}}$$

$$L = 0.81 \text{ mH}$$

This was achieved by using a 10mH and a 1mH in parallel, which gives 0.91mH. This allows the capacitor to adjust the resonant frequency around the calculated value. At the resonant frequency, a simplified estimate of the impedance *Z* is:

$$Z = 2 \times (2\pi f_0 L)$$
  
=  $4\pi \times 500 \times 10^3 \times \frac{1}{\frac{1}{10} + \frac{1}{1}} \times 10^{-3}$   
= 5700  $\Omega$ 

The actual value is much more complicated to calculate, due to the phase difference between the inductor and capacitor. To provide a good degree of filtering, a 10K resistor was chosen as R. The output of the filter was connected to an oscilloscope, which showed that it was significantly more like a sine wave than the input. It was not possible to tune the circuit to give a perfect sine wave, but this does not matter too much, as the filter has greatly reduced the higher harmonics being produced from the output. The output from a mains transformer at 12V RMS was connected to the output of the filter, and the oscilloscope showed that very little of the 50 Hz signal was passing through to the input. This prevents the output NOR gate being affected by a large AC signal at its output.

When the oscillator was run and the AC voltage applied to the output of the filter, there was little discernible difference between the output and a pure sine wave. It is likely that the transformed mains sine wave would swamp the small high frequency output anyway.

### **Receiver filtering**

Now a signal has been imposed on the mains, it needs to be extracted at the receiving end. The first hurdle to be overcome is to filter out the 50 Hz mains frequency. Again an LC filter is required to filter out any noise present on the mains line. A series LC filter could be used as before, except it has a low impedance, when it is better for the receiving end to have a high input impedance. The alternative is to use a parallel LC filter, which does have a high input impedance. This is shown below:



The resonant frequency is the same as before, at  $1/2\pi\sqrt{LC}$ . Therefore, the same values of inductor and capacitor as before can be used. Since they are in parallel, the impedance can be estimated by:

$$\frac{1}{Z} = \frac{1}{2\pi fL} + 2\pi fC$$

$$\frac{1}{Z} = \frac{1}{2\pi fL} + \frac{4\pi^2 f^2 CL}{2\pi fL}$$

$$Z = \frac{2\pi fL}{1 + 4\pi^2 f^2 CL}$$

$$Z = \frac{2858}{1 + 1.12}$$

$$Z = 1350 \ \Omega$$

Therefore, to minimise attenuation of the desired frequency while allowing a good range of attenuation for other frequencies, a  $470\Omega$  resistor was used for R.

This gave an output signal of approximately 200mV peak-to-peak, of which it could be seen that there was a considerable fluctuation due to the 50 Hz mains signal creeping through. To filter this out, another LC filter could be used. However, the variable capacitor used is bulky and expensive, and the system would need complicated tuning if more than one were used. In this situation, all that is required is to filter off the mains signal. This could be performed with a high pass active filter, but this would be operating very close to the frequency limits of the op-amp, and a filtering circuit might generate higher harmonics which the op-amp could not respond fast enough to. For these reasons, a simple passive RC high pass filter was chosen:



As the current that can be supplied by the LC filter is very small, the impedance of the RC filter needs to be as high as possible. This can be achieved by making R very large, so little current will be drawn. 100K is a suitable value. The filter will start to attenuate at the break frequency, and has a shallow increase in attenuation as the frequency decreases. To filter off the 50 Hz mains frequency, but leave a wide band for the signal, a break frequency of 100 kHz was chosen. The capacitor value can be calculated as shown below:

$$f_0 = \frac{1}{2\pi RC}$$

$$C = \frac{1}{2\pi fR}$$

$$= \frac{1}{2\pi \times 100 \times 10^3 \times 100 \times 10^3}$$

$$= 15 \text{ pF}$$

This could be affected by board capacitance or noise, so it was decided to reduce the resistor value to 10K and increase the capacitor value to 150 pF.

When the RC filter was in place, it could be seen that it was filtering off a good proportion of the 50Hz mains signal, but not all of it. To remedy this, three RC filters were connected in series to the signal:



This virtually eliminated the 50 Hz interference, at the expense of the 500 kHz signal, which was reduced to around 75mV peak-to-peak in size. Therefore this will need amplifying before it is converted to a digital signal.

## **Receiver amplification**

The 75mV 500 kHz signal needs to be amplified to make it into a manageable amplitude. There are three main types of amplifier that could be used here, op-amp, bipolar transistor or FET. Discrete transistor circuits are more complicated than op-amp based systems, and some rely on a particular type of transistor having particular characteristics. Therefore it was decided to use an op-amp amplifier.

As the frequency being used is high, the standard 741 cannot be used and so high frequency op-amps are required. As the closed loop gain of any op-amp decreases with frequency, several op-amps are necessary, each amplifying by a small amount. The OP282 and AD711 op-amps were chosen because they were able to operate at high frequencies and had high slew rates. The AD711 is a video amplifier, designed for unity gain operation at high frequencies. This can be used to buffer the signal when it has been amplified by the OP282, which is a dual op-amp.

One half of the OP282 was used in non-inverting amplifier mode to form an amplifier with gain 11:



Power supplies of  $\pm 15V$  were used with all op-amps. This amplifier gave reasonable performance, and seemed to be amplifying the signal properly. There was a considerable amount of distortion which showed up as blurring on the oscilloscope, but it did not appear to be significant as the main sine wave was propagating as expected. This amplifier gave an output of about 800mV peak-to-peak at the same frequency as the input.

This needs further amplification. To do this, the other half of the OP282 was used in the same non-inverting amplifier circuit as before. This circuit did not work properly, either giving an erratic output or a very small one. Adding extra decoupling to the supply rails, and replacing the OP282 chip had no effect. The input voltage to the amplifier continued to oscillate as before.

The OP282's data sheet showed what the problem was. This device has a slew rate of  $8V/\mu s$ , while the amplifier circuit is trying to produce a 9V signal at 500 kHz. In one cycle the voltage goes from positive to negative to positive again, so in 1 $\mu$ s the output has to slew 9V. This is above that rated for the device, so this is likely to be causing the problems with the output.

The OP282 could be replaced by another type of op-amp, but it is doubtful whether cheap op-amps would be able to give the gain needed at the frequencies required.

## Rethink

As well as the problems with the op-amps, the circuit would only work when one type of transformer was being used to supply the 12V AC. Other types would cause a significant drop in the transmission of the carrier signal. As the mains circuit in a house is constantly changing, with devices being switched on and off, the receiver circuit would be susceptible to these changes.

I also realised that the impedance of the transformer was causing attenuation by interfering with the filtering circuit, and effectively filtering out the carrier signal. The method of overcoming this problem that is used in baby alarms, which use the mains as a transmission medium, is to add another coil to the inductor used in the filtering circuit, which converts it into a mains transformer. As it is not possible to directly connect to the mains for the purposes of this project, it was not possible to try this.

For these reasons, I decided to abandon the mains, and modify the circuit I had built to make it transmit along a single wire link. The system was designed so that if direct mains connection were possible it could easily be modified to transmit through the mains.

### Wire link transmitter

The frequency of the oscillator was reduced, so that problems with op-amp slew rates could be avoided. To minimise interference between the two channels, I decided to make one channel have a 100 kHz carrier and the other to have a 10 kHz carrier. The 10 kHz carrier could cause an audible noise if equipment resonated at that frequency, but it is likely that, if passed through the mains, it would be tiny compared to the 50 Hz signal. To ensure that the channels did not interfere with each other, the two channels were built and tested simultaneously.

The 100 kHz carrier was produced using the same oscillator circuit as before, with 4.7nF capacitors instead of 1nF capacitors. This increases the period by 4.7 times, which gives approximately 100 kHz. As with virtually all RC oscillators, it is not possible to determine the frequency precisely, but as long as any filters are tuned to match this output frequency the exact value will not matter.

The 10 kHz carrier was produced by the same principle, except with 47nF capacitors. When both of the output frequencies were displayed on an oscilloscope, they were shown to be roughly correct. Both of the enable pins on the oscillators were taken low by wire to permanently turn then on for the purposes of testing.

The same transmitter LC filter was used as before, although the inductor value had to be modified for the new frequency:

$$f_{0} = \frac{1}{2\pi\sqrt{LC}}$$

$$\sqrt{LC} = \frac{1}{f_{0}^{2}\pi}$$

$$L = \frac{1}{4\pi^{2}Cf_{0}^{2}}$$

$$L = \frac{1}{4\pi^{2}.125 \times 10^{-12}.(10 \times 10^{3})^{2}}$$

$$L = 20.2 \text{ mH}$$

The closest value to hand was a 47mH, so two were used in parallel to give 23.5mH. The impedance of this combination can be calculated as before:

$$Z = 2 \times (2\pi f_0 L)$$
  
=  $4\pi \times 100 \times 10^3 \times 23.5 \times 10^{-3}$   
= 29500  $\Omega$ 

To produce a potential divider with a reasonable range of output voltages, a 47K resistor was used as the resistor between the output and ground.

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

This was repeated for the other side of the link, which has to pass 10 kHz.

$$f_{0} = \frac{1}{2\pi\sqrt{LC}}$$

$$\sqrt{LC} = \frac{1}{f_{0}^{2}\pi}$$

$$L = \frac{1}{4\pi^{2}Cf_{0}^{2}}$$

$$L = \frac{1}{4\pi^{2}.125 \times 10^{-12}.(10 \times 10^{3})^{2}}$$

$$L = 2.02 \text{ H}$$

This is a very large inductance, which would be expensive to make from ready made inductors as the largest value I was able to obtain was 47mH. It would be possible to wind an inductor specially, but without any form of accurate inductance meter, its value can only be determined by trial and error. This is obviously not a very satisfactory solution.

The best compromise it was possible to find was to use four 47mH inductors in series to produce a 188mH inductance. This filters off some of the high harmonics of the 10 kHz square wave, and so prevents them interfering with the 100 kHz sine wave from the other channel. The filter does not filter off all the harmonics, so the output is not perfectly square, but this should not cause many problems.

The impedance of the inductor/capacitor combination is as follows:

$$Z = 2 \times (2\pi f_0 L)$$
$$= 4\pi \times 10 \times 10^3 \times 188 \times 10^{-3}$$
$$= 24000 \ \Omega$$

Therefore a 47K resistor was used as with the 100 kHz transmitter.

The outputs of both of the transmitter circuits were joined together with a long length of single core wire, to simulate a noisy connection. In practice, the signal would be carried on screened cable, which would significantly reduce the noise problem. An oscilloscope, connected to the wire, showed that when one transmitter was activated by taking its enable input low, the output frequency was present on the transmission line. When both were triggered the output trace was blurry suggesting that the oscilloscope could not lock onto either of the frequencies. This suggests that there is a complex waveform being produced, which is difficult to detect on an analogue oscilloscope.

### Wire link receiver

Now an transmission signal has been produced, its two component frequencies need to be separated, so that they can be detected individually. Previously, another of LC filter was used as the receive filter. This was for the mains based system, where there is a need to filter out the 50Hz sine wave, as well as any other sources of interference.

This system uses a wire link, so these extra signals should not be present. Therefore, using an LC filter is overkill when a simpler filter could be used instead. An LC filter would be required if this system were being converted to mains operation, but the whole filter would have to be redesigned anyway to incorporate a transformer which also acts as the inductor in the circuit.

The simple alternative to an LC filter is to use an RC filter. These have a much greater bandwidth than LC filters, so each section can filter off the range of frequencies containing the unwanted carrier, leaving a frequency band containing the desired carrier frequency.

For the 100 kHz receiver, a high pass RC filter is required to remove the 10 kHz carrier. At low frequencies, a capacitor has a high resistance, so needs to be at the top of a potential divider to reduce the amplitude of the low frequency signals. Therefore a high pass filter is as shown below:



The break frequency is given by  $1/2\pi RC$ . Before, using a 100K resistor gave a very small capacitor value. To prevent this problem, a 1K resistor was used. This means that the input impedance of the filter is reduced, but this is necessary to give a reasonable capacitor value which is less subject to noise and board capacitances. This can therefore be calculated:

$$f_0 = \frac{1}{2\pi RC}$$

$$C = \frac{1}{2\pi fR}$$

$$= \frac{1}{2\pi \times 100 \times 10^3 \times 100 \times 10^3}$$

$$= 1.6 \text{ nF}$$

The nearest value to this is 1.5nF, and so this was used.

When this circuit was connected to the transmission line, its output showed that the 100 kHz signal was clearly visible, although it was blurred when the 10 kHz oscillator was activated. This problem was solved before by placing a number of RC filters in series, to increase the attenuation:



Single RC filter

Two RC filters in series

Two of these filters in series helped, but three removed most of the blurring from the signal, indicating it was almost free of low frequency carrier. The output signal was about 100mV peak-to-peak in size.

For the 10 kHz receiver, the 100 kHz carrier needs to be filtered out. This can be achieved by an RC low pass filter. This is similar to an RC high pass filter, except with the resistor and capacitor transposed:



With a high frequency input, the capacitor has a low resistance, and so pulls Vout down towards 0V, reducing the amplitude of the signal.

The break frequency of this system is again  $1/2\pi RC$ . As the break frequency is lower than the previous filter, higher value resistors can be used, which means that this circuit has a higher input impedance, and so loads the transmission line less. To give a break frequency of 10 kHz, 10K resistors were used. The capacitor value is then:

$$f_0 = \frac{1}{2\pi RC}$$

$$C = \frac{1}{2\pi fR}$$

$$= \frac{1}{2\pi \times 10 \times 10^3 \times 10 \times 10^3}$$

$$= 1.6 \text{ nF}$$

When this was constructed, it showed the same problem as before, namely blurring when both transmitters were activated. Putting four of these filters in series solved the problem. Presumably the problem with the output filtering from the transmitter has meant that the higher harmonics produced have increased the blurring. The output signal was around 75mV peak-to-peak in size.

#### Amplification

Both of the signals need to be amplified so they can be reasonably detected. As before, there are three types of possible amplification circuit, op-amp, FET or bipolar transistor. For simplicity, I decided to use an op-amp, since the problems with high frequencies encountered before are not as important, as the transmission frequencies are lower.

To avoid problems with slew rate, the gain for each op-amp amplifier circuit should not be too high. To amplify 75mV to a detectable 7.5V requires a gain of 100, which is potentially too much for a single op-amp. I therefore decided to use at least two op-amps for each channel. Since the OP282 used before has a high slew rate and good frequency response, as well as two op-amps on one IC, this is an ideal device for this purpose.

Of the two major amplifier configurations, inverting and non-inverting, the non-inverting amplifier has an input impedance equal to that of the IC, approximately 150M $\Omega$ , while the inverting amplifier has an input impedance equal to that of its input resistor. 150M is a much greater resistance than any discrete resistor, so the non-inverting amplifier will have a higher input impedance, which is desirable as it will be drawing current from a high impedance passive filter.

The non-inverting amplifier configuration is shown below:



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

The gain of this amplifier is

$$Gain = 1 + \frac{Rf}{Ra}$$

Therefore, to give a gain of 10, Rf must be 9 time Ra. The precise gain does not matter, so a 100K resistor can be used for Rf, and a 10K for Ra, to give a gain of 11.

This was tried with the 100 kHz signal and found to work without any problems involving the high frequency. The other OP282 was used to amplify the 10 kHz received signal, and this also worked.

The 100 kHz signal showed some degree of blurring on the oscilloscope, after it had emerged from the amplifier. This was removed by using another 1K/1.5nF passive filter attached to the amplifier's output to filter it off. This gave a signal about 800mV in size from both of the channels. This needs further amplification to allow digital processing of the signal.

As there was a spare op-amp on each of the OP282s, it seemed sensible to use them. They were tried using the same non-inverting amplifier configuration with gain 11. This worked again, producing large (about 8V peak-to-peak), relatively clean, output signals from both channels.

### Signal detection

Now we have a reasonable amplitude sine wave, this has to be converted to a logic level indicating the presence or absence of this sine wave.

There are a number of methods by which this could be achieved. A frequency-to-voltage converter could convert this to a voltage, which could then be compared with a reference voltage. This is not very satisfactory, as with no signal to converter will just pick up noise. A phase locked loop (PLL) could be constructed to detect only one precise frequency. However, PLLs are sensitive to noise, and may inadvertently lock onto the frequency from a nearby oscillator or digital circuit.

The amplitude of noise at the receiver output when the transmitter is disabled is about 1V peakto-peak, compared with an 8V p-p signal. It might therefore be possible to smooth the signal with a capacitor, as in a power supply, to give a level depending on the level of the input. If a threshold is taken between the 1V noise and 8V signal, the two can be distinguished.

This was tested with the 100 kHz receiver. Firstly, the signal was decoupled with a 10nF capacitor to remove any DC component. This worked, but converted the signal to  $\pm$ 4V, the negative component of which would cause problems with a logic chip. Therefore the negative component needed to be clamped with a diode. This produced a signal between 4V and -0.7V, a signal compatible with a logic gate. The problem with this is that if the amplitude of the signal were reduced significantly, say to  $\pm$ 2V, it would fall outside the threshold and so not be detected. To remedy this, I tried using a pair of resistors acting as a bias network. As negligible current flows through the decoupling capacitor, these resistors were used to pull the voltage after the decoupling capacitor to around the threshold of a logic gate. CMOS logic has a threshold of about 2.5V, so 100K and 220K resistors were used to pull the logic input to:

$$V = \frac{V_0 R_2}{R_1 + R_2}$$
  
=  $\frac{5 \times 220 \times 10^3}{100 \times 10^3 + 220 \times 10^3}$   
= 1.6V

This leaves about 1V margin for noise, while allowing signals as low as 1.5V to be detected. The diagram of this section is shown below:



This produced a reasonable output signal which oscillated around 1.5V. There was one problem however. While the voltage was clamped to prevent it going below -0.7V, there was no upper limit, so it would go up to about 10V with a strong signal. This would blow any logic chip connected to Vout which was powered from 5V. To prevent this, the signal diode was replaced by a 5.1V zener diode. When Vout tries to go above 10V, the diode has 5.1V across it and so pulls it down, clamping it to 5.1V. If it tries to go below -0.7V, the diode conducts, and so clamps it at -0.7V.

This produced a good signal, which seemed to be ready for feeding into a logic gate. The same circuit was constructed for the 10 kHz receiver, and it appeared to be working properly.

Now the signal has to be fed into a logic gate to buffer the signal. It has to be a CMOS chip, as TTL devices draw too much current, and the decoupling capacitor has a very small current supplying capability. A 4069 was tried by connecting its input to Vout of the 100 kHz receiver shown above. This caused the voltage at Vout to fall dramatically, so that the gate did not detect it. This appears to be a symptom of the device drawing too much current. It was therefore replaced with a 4001 with the inputs of each gate connected together, forming a quad inverter chip. When this was tried, the output did not show a sign of any oscillation, and stayed high. When the transmitter was turned off, the output went low. The circuit was therefore working, but without any smoothing components. This is a little strange, but it is possible that the propagation delay on the device is greater than the 100 kHz.

When this circuit was tried on the 10 kHz channel, the output was a noisy square wave. I tried passing it through another NOR gate inverter, which squared it up considerably. This, however, still needed conversion to a logic level by smoothing it. A number of capacitor values were tried,

but these all caused the signal to drop below the threshold of the CMOS gate. Finally, a large 470nF capacitor was tried between the gate output and +5V This did the trick, giving a reasonable high logic level when the transmitter was enabled, but not taking a long time to fall to a low logic level when the transmitter was disabled.

The data link was tested by applying a square wave to the input and examining the output waveform. More details on this are shown in the Evaluation section, but it was found that the most the 10 kHz side could manage was 80 Hz, while the 100 kHz side could handle 2500 Hz.



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

### **Remote control module**

Now the master control unit and data link have been designed, there needs to be a system to connect to the end of the data link and communicate with the master control unit. If mains transmission were being used, this system would either be mounted in the equipment that needs to be controlled, or in a special plug which would contain the extra electronics as well as the standard fuse and cable clamp. This method would involve no modifications to equipment, and could probably be performed by the householder. Since mains transmission is not possible, the module cannot be used in this way, but it will be designed as if it can use the mains, so that the system is as close as possible to a production system.

What is required is a system to connect to the end of the wire data link, which would be the mains wiring in a production system, and control a device or devices under the commands sent through the data link. Since it would be impractical to have a separate data link wire from the master control unit for each appliance (this would be impossible with mains anyway), all the devices have to communicate along the same length of wire. It would be very difficult for each device to use a different carrier frequency on the data link, as this would severely limit the maximum number of devices possible, and would require very carefully tuned circuits, which is something that should be avoided in a production system.

The alternative is to have a simple two-way link, as has already been built, so that each device receives all the transmitted data, and then determines whether the digital data it receives is directed towards it. Such a system is similar to a computer network – the data is transmitted over a few wires to all computers, but one machine ignores anything not specifically for it.

This would require some intelligence, which it is obviously not present in a simple logic system built out logic components such as counters and shift registers. A microprocessor system similar to the master control unit could be used, but this would be vast overkill, since all the system needs to do is decode the data link signal and control a device, which does not take much processing power. In addition, the microprocessor system would be very difficult to fit into the space contained within a large mains plug.

As detailed before, another possible choice is to use a microcontroller. This is essentially an entire microprocessor system on one IC, with a number of input and output ports. Some contain an internal ROM or EPROM so that the chip itself can be programmed, reducing the need for external circuitry. There are many possible devices that fit into the microcontroller category, and, like microprocessors, each family and usually each device is unique in design, so the device used has to be chosen from the start. Suitable families include the Motorola 68HC11, the ARM Thumb, the Arizona Microchip PIC, the Zilog Z8 family, the SGS SG62 family and the Intel/ Philips 8031.

Of these, the Microchip PIC seems the best choice for a number of reasons. Firstly they are extremely cheap – prices go as low as £1.89, which is not bad for the amount of computing power that a PIC provides. Secondly, the PIC itself is reasonably powerful – executing more instructions per second than many 8 or 16 bit computers. The amount of work done per instruction is less, but they still have ample power for this task. Finally, the entire system is packaged in one IC – it requires only a crystal or RC network to provide a clock, and a 2 to 6V power supply. Of the many devices in the PIC range, the PIC16C84 was chosen because it was an on-chip EEPROM (electrically erasable PROM) program memory, which means that software

development times are substantially shortened, as the chip can be erased instantly, instead of waiting for up to 20 minutes for an EPROM based microcontroller to erase under ultraviolet light. Other PIC devices have additional features such as analogue to digital converters, but the EEPROM feature is more important for development purposes. The devices in the PIC range are reasonably compatible with each other, so code initially written on the 16C84 could be transferred to other devices in the range which have these other features.

The 16C84 comes in an 18 pin plastic DIP package, which will easily fit in breadboard. For reference, the specification is shown in Appendix A, and includes a pinout diagram of the device.

The PIC was given a 5V power supply, and it /MCLR (reset) signal was pulled high with a resistor to allow it to execute a program. The PIC has an internal power-on reset, so an external one is not needed. Having done this, all that needs to be connected to it to make it function is an RC or crystal oscillator to provide the clock. Since the transmission line will carry a serial signal of some sort, an accurate timebase is essential, and this can only be provided by a crystal clock. The 16C84 is supplied in two versions, rated at 4 and 10 MHz respectively. Since this system will not be running very quickly, there is no need for the more expensive 10 MHz version. Therefore a 4 MHz crystal was used in the crystal oscillator circuit below:



A simple test program, shown below, signified that the PIC was working perfectly by producing a square wave on all the pins of the Port B input/output port. The PIC was programmed in a programmer attached to the parallel port of a computer, and then inserted into the breadboard to be tested.

LIST P=16C84 MOVLW 0 TRIS PORT\_B OPTION LOOP SLEEP INCF PORT\_B,F GOTO LOOP END

### **PIC** hardware

In addition to the simple system support hardware, extra hardware is required for this particular application. This needs to be connected to the 13 input/output pins provided by the 16C84, which are composed of a 5 bit port (Port A) and an 8 bit port (Port B).

Firstly, a means is require to allow each device attached to the data link to be able to recognise that a command is for it. One possibility is to hard-wire an identification code into each PIC, so that each device is unique. This can be done either in the main program memory or in a special set of ID locations set aside for this purpose. The problem with this is that the devices could not be mass produced very easily, as each one would be a slightly different. It also means the code cannot be changed after production.

An alternative is to use a hardware method, where the PIC reads the code from external hardware through an input port. The obvious way to do this is to use an 8 way DIP switch, providing 256 different combinations. If this were connected directly to an input port, it would occupy 8 of the 13 I/O lines, which is not ideal. A better idea is to treat the 8 bit output port like a processor bus, and only connect the DIP switch to the 8 bit port when it is required. This can be performed with a tristate. Since the 74LS244 was used before, there is no reason why not to use it again. The 244 has two active low enable pins, one controlling a block of 4 bits. If these are connected to Port B only when the output pin is low. For this pin, pin RA0 on Port A was chosen, as it is a general purpose pin. The diagram of the DIP switch system is shown below:



This was tested, and did work. The switches were set to binary 7, which is the code used to signify the immersion heater in the master control software (see later).

The other major hardware that is required is a means of controlling the electrical device itself. If it were a resistive or inductive device, a triac could be used to give proportional control, but this cannot be done without direct access to the mains. A system designed to work on low voltage AC would require considerable modification to cope with mains voltages. The alternative is to use a relay for simple on/off control. This isolates the high voltages, and the system will be able to switch any voltage up to the maximum rating of the relay. A production system would require proportional control, an this could be managed with a triac, but a relay will suffice for the purposes of this project.

A relay coil requires a significant amount of current, more than a PIC output pin could supply. To be able to switch large currents, large relays generally require 12V, which could not be provided by the PIC anyway. Therefore, a buffer is needed between the PIC output pin and the relay. There are many ICs which could perform this function, but this is overkill since only one output is needed. The simplest method to do this is to use a transistor. A BFY51 NPN transistor can handle the current drawn by a relay, and has enough current gain to be driven by a PIC output pin. It was tried in the standard configuration shown below, including a protection diode across the relay coil:



This worked quite well, and was able to be powered by the output current from a PIC pin.

To enable the PIC and relay to be powered from a single power supply, the unit needs a voltage regulator to convert 12V to 5V. This simplest regulator available is a single 78L05 device, which only requires two decoupling capacitors to perform this function, and can supply 100mA. One was connected as shown below, and found to work:



The only hardware left to interface with is the data link itself. The serial interfacing code (see next section for further details) needs to use RA4 as the receive pin, and can use any pin as the transmit pin. Since RA2 is not being used, it seems sensible to use this. The data link has a digital input and a digital output, so they were connected directly to these I/O pins. They could not be tested without the full serial interfacing code being present.

### Remote module software

The PIC in the remote module needs to be programmed to accept commands from the data link and then decode them. Because this is mainly a hardware project, the software will not be examined in too much detail, and so only a basic outline of it is presented here, as well as the full source code to allow it to be inspected more thoroughly if desired.

The data link is a serial system, so a serial data stream has to be sent along it. Performing serial communications in software is a common task for a PIC, so the manufacturers, Arizona Microchip, have written a software routine to do this in Application Note AN555, which is freely distributable. Since there is no point in rewriting the code myself, I have included a slightly modified version of this code in the module software. This is clearly marked so it is possible to determine the code I have written.

A flow chart for the software is shown below. The numbers enable sections in the source code to be linked with this diagram.



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

Essentially, the module listens for an ID code. If it is not its own, it waits until the end of the data packet. If it is, it controls the device and sends a byte back to the master control unit, so it knows that the device has responded. It then waits for the end of the data packet. This allows variable length data packets, so that, for example, an oven could be controlled by sending more data bytes which set the temperature, control whether the fan is turned on, and so on, while this would be ignored by all other devices.

The code is split into five chunks, four of which (are related to the serial link, and are direct copies from Application Note AN555. The main control code for the remote control unit is contained in MAIN.ASM, which is shown below. The other four files, which are copied from AN555, are not shown here. Essentially they provide the routines GetChar and PutChar and their support software.

#### Main routines

| TITLE<br>SUBTITLE                                                            | "Home Automation System Remote Control Unit"<br>"Basic on/off control program, version 1.00" |                                                                                                                                            |  |  |  |
|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Processor<br>Radix DEG                                                       | 16C84<br>C                                                                                   |                                                                                                                                            |  |  |  |
| include                                                                      | "16Cxx.h"                                                                                    |                                                                                                                                            |  |  |  |
| ; set up RS232 seria                                                         | l link                                                                                       |                                                                                                                                            |  |  |  |
| _ClkIn equ<br>_BaudRate set<br>_DataBits set<br>_StopBits set<br>implemented | 4000000<br>75<br>8<br>1                                                                      | ; Input Clock Frequency is 4 Mhz<br>; Baud Rate (bits per second) is 75<br>; 8 bit data, can be 1 to 8<br>; 1 Stop Bit, 2 Stop Bits is not |  |  |  |
| #define _PARITY_ENAE<br>#define _ODD_PARITY<br>#define _USE_RTSCTS           | ELE FALSE<br>FALSE<br>FALSE                                                                  | ; NO Parity<br>; EVEN Parity, if Parity enabled<br>; NO Hardware Handshaking is Used                                                       |  |  |  |
| include                                                                      | "rs232.h"                                                                                    |                                                                                                                                            |  |  |  |
| ; settings for remot                                                         | e unit                                                                                       |                                                                                                                                            |  |  |  |
| id_value equ<br>#define id lat                                               | 0x20                                                                                         | ; reserve memory location to<br>; store ID value<br>; pin connected to 74LS244 enable                                                      |  |  |  |
| #define relay                                                                | _porta,1                                                                                     | ; pin to use for relay                                                                                                                     |  |  |  |
| ORG _ResetV<br>goto Start                                                    | ector                                                                                        |                                                                                                                                            |  |  |  |
| ORG _IntVec<br>goto Interru                                                  | tor<br>pt                                                                                    |                                                                                                                                            |  |  |  |

```
; Main program
```

| Star               | Start:     |                  |                                    |                                     |                |  |  |
|--------------------|------------|------------------|------------------------------------|-------------------------------------|----------------|--|--|
|                    | movlw      | OxfE             | ;                                  | make port A all inputs except RA0   |                |  |  |
|                    | movwf      | _trisa           |                                    |                                     |                |  |  |
|                    | movlw      | 0xFF             | ;                                  | make port B all inputs              |                |  |  |
|                    | movwi      | _trisb           |                                    |                                     | ~              |  |  |
|                    | movlw      | 0x00             | ;                                  | enable 74LS244, reset rest of port  | (1)            |  |  |
|                    | movwf      | _porta           |                                    |                                     |                |  |  |
|                    | movi       | _portb,W         | ;                                  | read port B value into W register   |                |  |  |
|                    |            | ld_value         | ΄.                                 | disable 7418244                     |                |  |  |
|                    | movwf      | porta            | '                                  | disable /4L5244                     |                |  |  |
|                    | IIIO V W L | _por ca          |                                    |                                     |                |  |  |
|                    | call       | InitSerialPort   | ;                                  | set up serial port                  |                |  |  |
| NewCommand:        |            |                  |                                    |                                     |                |  |  |
|                    | call       | WaitForNext      | ;                                  | get a byte from data link           | 2              |  |  |
|                    | mourf      | ByBog w          |                                    | morro buto into M                   | C              |  |  |
|                    | IIIOVL     | KXREG,W          | '                                  | move byte into w                    |                |  |  |
|                    | subwf      | id_value,W       | ;                                  | subtract W from ID, put in W        | (3)            |  |  |
|                    | btfsc      | Z                | ;                                  | is Z set (bytes are equal => ID is  | ours)          |  |  |
|                    | goto       | <br>CommandForUs | ;                                  | if so, receive command              |                |  |  |
|                    | -          |                  |                                    |                                     |                |  |  |
|                    |            |                  | ;                                  | if not, wait until \$FF is received |                |  |  |
| Wait               | ForEnd:    |                  |                                    |                                     |                |  |  |
|                    | ap11       | WaitForNort      |                                    | act a but from data link            | $\overline{7}$ |  |  |
|                    | Call       | Waltroinext      | '                                  | get a byte from data fink           | $\odot$        |  |  |
|                    | movi       | RxReg,w          | ;                                  | move byte into W                    |                |  |  |
|                    | sublw      | OxF'F'           | ;                                  | subtract SFF from received byte     |                |  |  |
|                    | DTISS      | _Z<br>WaitEcrEnd | ;                                  | is 2 clear (not SFF)                |                |  |  |
|                    | golo       | Waltrorend       | '                                  | II NOT CATTY ON WAITING             |                |  |  |
|                    | goto       | NewCommand       | ;                                  | if so, wait for a new command       |                |  |  |
| CommandForUs:      |            |                  |                                    |                                     |                |  |  |
|                    |            |                  |                                    | ant a basta forem data lint         | ( <b>4</b> )   |  |  |
|                    | Call       | WallForNext      | '                                  | get a byte from data fink           | $\bigcirc$     |  |  |
|                    | btiss      | RxReg,7          | ;                                  | is it above \$7F (bit 7 set)        |                |  |  |
|                    | bCI        | relay            | ;                                  | if not turn off relay               | 0              |  |  |
|                    | btfsc      | RxReg,7          | ;                                  | is it above \$7F (bit 7 set)        | (5)            |  |  |
|                    | haf        | relav            | :                                  | if so turn on relay                 |                |  |  |
|                    | DDI        | icity            | ,                                  | ii bo, cain on icia;                |                |  |  |
|                    | movf       | id value,W       | ;                                  | read ID value                       |                |  |  |
|                    | movwf      | TxReg            | ;                                  | put it transmit register            |                |  |  |
|                    |            |                  |                                    |                                     | ക്ര            |  |  |
|                    | call       | PutChar          | ;                                  | send it                             | $\bigcirc$     |  |  |
| CommandSendingAck: |            |                  |                                    |                                     |                |  |  |
|                    | btfsc      | _txmtProgress    | ;                                  | has it finished?                    |                |  |  |
|                    | goto       | CommandSending   | уАс                                | ck ; if not, wait until it has      |                |  |  |
|                    |            | _                | ;                                  | - could do other jobs here          |                |  |  |
| goto WaitForEnd    |            | ;                | it so, wait for end of data packet |                                     |                |  |  |

```
; routine to wait for next byte to be received
WaitForNext:
    call
        GetChar
                        ; wait for a byte reception
    btfsc _rcvOver
                       ; _rcvOver Gets Cleared when a Byte Is
                        ; Received (in RxReg)
                       ; USER can perform other jobs here,
           WaitForNext
    goto
                         ; can poll _rcvOver bit
    return
; ****** Code below this point is copied from AN555 ********
RS-232 Routines
Interrupt Service Routine
;
; Only RTCC Inturrupt Is used. RTCC Inturrupt is used as timing for Serial
; Port Receive & Transmit
; Since RS-232 is implemented only as a Half Duplex System, The RTCC is
; shared by both Receive & Transmit Modules.
      Transmission :
;
                     RTCC is setup for Internal Clock increments and
;
;
                    interrupt is generated when
                     RTCC overflows. Prescaler is assigned, depending on
;
                    The INPUT CLOCK & the
;
                     desired BAUD RATE.
;
      Reception :
;
                     When put in receive mode, RTCC is setup for external
;
;
                    clock mode (FALLING EDGE)
                     and preloaded with 0xFF. When a Falling Edge is
;
                    detected on RTCC Pin, RTCC
;
                     rolls over and an Interrupt is generated (thus Start
ï
                    Bit Detect). Once the start
                     bit is detected, RTCC is changed to INTERNAL CLOCK
;
                    mode and RTCC is preloaded
;
                     with a certain value for regular timing interrupts to
                    Poll RTCC Pin (i.e RX pin).
Interrupt:
    btfss
           _rtif
    retfie
                                ; other interrupt, simply return &
                                ; enable GIE
;
; Save Status On INT : WREG & STATUS Regs
;
    movwf SaveWReq
    swapf _status,w
                                ; affects no STATUS bits : Only way OUT
                                ;to save STATUS Reg ?????
    movwf
          SaveStatus
ï
          _txmtProgress
    btfsc
          _TxmtNextBit
    goto
                               ; Txmt Next Bit
    btfsc
          _rcvProgress
    goto
           _RcvNextBit
                               ; Receive Next Bit
           _SBitDetected
                               ; Must be start Bit
    goto
RestoreIntStatus:
    swapf
           SaveStatus,w
```

```
Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com
```

```
movwf _status
   swapf SaveWReg, F
swapf SaveWReg,w
                          ; restore STATUS Reg
                         ; save WREG
                         ; restore WREG
   bcf
         _rtif
   retfie
;
;
;
; Configure TX Pin as output, make sure TX Pin Comes up in high state on
; Reset
; Configure, RX_Pin (RTCC pin) as Input, which is used to poll data on
; reception
;
 Program Memory : 9 locations
;
         :
                 10
 Cycles
;
InitSerialPort:
   clrf SerialStatus
   bcf
                                ; select Page 0 for Port Access
         _rp0
   bsf
         ΤX
                                ; make sure TX Pin is high on
                                ; powerup, use RB Port Pullup
   bsf
         _rp0
                                ; Select Page 1 for TrisB access
                                ; set TX Pin As Output Pin, by
   bcf
         ΤX
                                ; modifying TRIS
 if _USE_RTSCTS
   bcf
        _RTS
                                ; RTS is output signal,
                                ; controlled by PIC16Cxx
   bsf
         _CTS
                                ; CTS is Input signal, controlled
                                ; by the host
 endif
   bsf RX_Pin
                                ; set RX Pin As Input for
                                ; reception
   return
;
include "txmtr.asm"
                          ; The Transmit routines are in file
                           ; "txmtr.asm"
   include "rcvr.asm"
                           ; The Receiver Routines are in File
                           ; "rcvr.asm"
END
```

### **Master control transmitter**

Since the master control unit has to send data along the transmission line at a very slow 75 bits per second, it will spend a long time doing this, which will slow the system down. As PICs are very cheap and simple, it seems sensible to dedicate another PIC as a transmitter, which leaves the master control unit free to get on with other things while transmission is taking place. The intelligence provided by the PICs also allows additional features such as error correction to be programmed into them, which makes the data link more robust.

The power and crystal connections are similar to before, but this time the PIC needs to be connected directly to the main control unit. The most obvious place for this is one of the 6522's input/output ports, which allows parallel data transmission to and from the PIC. Since the 6522's Port A allows automatic read and write handshaking, which means the port will automatically generate a data strobe and an acknowledge signal when talking to another device, this seems the better port to use, and can be connected to the PIC's Port B. PIC I/O lines RA0 and RA1 can be used as handshaking lines with the 6522's to control data transfer on the bus. This leaves RA4, which must be the serial receive line, and RA2, which can be the transmit line as before. The last line, RA3, can be used to generate an interrupt when a serial byte is received by being connected to the 6522's CB1. The circuit diagram below shows these connections:



The reset line goes to the control unit's master /RESET signal, so that everything is reset at the same time.

This could not be tested without the software, which is detailed below. It is similar to that of the remote module, as it uses the same serial transmit/receive code, but employed in a different situation, so the main controlling code is different.

The software is outlined in the flowchart below:



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

The listing is shown below. It uses the same serial files as before, and, to save space, the second half of the source file has been omitted, as it contains the same code as in the remote unit's code listing. The omitted section is headed RS232 Routines in that listing.

TITLE "Home Automation System Master Control Unit" "Data link transceiver, version 1.00" SUBTITLE 16C84 Processor Radix DEC EXPAND include "16Cxx.h" ; set up RS232 serial link \_ClkIn 4000000 ; Input Clock Frequency is 4 Mhz equ \_BaudRate set 75 ; Baud Rate (bits per second) is 75 \_DataBits set 8 ; 8 bit data, can be 1 to 8 ; 1 Stop Bit, 2 Stop Bits is not \_StopBits set 1 implemented #define \_PARITY\_ENABLE FALSE ; NO Parity #define \_ODD\_PARITY ; EVEN Parity, if Parity enabled FALSE #define \_USE\_RTSCTS FALSE ; NO Hardware Handshaking is Used include "rs232.h" ; settings for transceiver unit #define ; define 6522 pins CA1 \_porta,0 #define CA2 \_porta,1 #define CB1 \_porta,2 ORG \_ResetVector goto Start ; ORG \_IntVector Interrupt goto ; Main program ; Start: (1)movlw 0xFF ; make port B inputs movwf \_trisb ; make all Port A high (otherwise movlw 0xFFmovwf \_porta ; may cause 68K IRQ when TRIS set) ; make RA3 (CB1) and RA0 (CA1) movlw 10110b ; outputs, rest inputs movwf \_trisa call InitSerialPort ; set up serial port

CheckSend: ; is CA2 low (byte sent)? btfss CA2 (2) ; if so, transmit 6522 byte goto SendTxdByte ; wait for a byte reception call GetChar ; if nothing has been received btfsc \_rcv0ver (4) goto CheckSend ; carry on waiting ; if something has, read it GetRxdByte: ; move received byte into W movf RxReg,w (5) ; and then to port B movwf \_portb bcf CB1 ; assert CB1 (cause 68K IRO) WaitFor6522Ack: (6)btfsc ; wait for 6522 reply CA2 WaitFor6522Ack ; not yet? Carry on waiting.. goto bsf CB1 ; assert CB1 (clear IRQ) (7) ; reply to write bcf CA1 ; make sure 6522 has got it nop nop nop nop nop nop bsf CA1 ; and deassert CA1 goto CheckSend ; and now wait for next SendTxdByte: (3)movf \_portb,W ; read value on Port B movwf ; get ready to transmit TxReg ; signify data has been taken bcf CA1 call PutChar ; send it SendingTxdByte: ; has it finished? btfsc \_txmtProgress ; if not, wait until it has goto SendingTxdByte bsf CA1 ; deassert acknowledge line goto CheckSend ; if so, wait for next one

### Master control software

This is the main chunk of software that controls the master control unit, and so controls the entire system. Mainly what it does is handles the menu system by sending it through the serial port. It was not possible to use a modem, because two telephone lines would be needed for testing, but the software would need little modification to do this. For the purposes of demonstration, only one appliance can be controlled by the software because there is only one receiver module, but this could easily be extended to up to 255 appliances.

The software is split into four chunks, all of which I have written and are thus included here. The main program controls the menu system and contains most of the code. The interrupt service routines handle interrupts generated by the various devices in the master control unit, and are mostly separate for the main program. The exception code handles any exceptions triggered by the 68000 by displaying a flashing pattern on the LED port. It also contains the beginnings of an operating system, as the TRAP command is used to provide access to a number of software routines as if they were additional instructions. In this version, the only routines present are real time clock accessing routines, as well as a means of calling instructions that can only be executed in supervisor mode. In a proper operating system, this would be extended to access large numbers of routines, in a similar way to that of the INT instruction of the 8086 and the SWI instruction of the ARM. Finally, the definitions file defines names for a number of numeric constants, which improves the clarity of the assembly listing.

The full software listings are shown in Appendix B.

When the unit is first reset, the following menu in sent through the master control unit's serial port, and appears on a terminal connected to it:

#### Home Control System

Version 1.09 (9 March 1997)

- 1) Configure system
- Control appliance now
- Set timed event
- List current timed events
- Clear timed event
- View current conditions
- 7) Goodbye

Please enter a number :

This is the main menu, which contains the main control options. Of these, 4 and 5 do not do anything in the current version of the software, but they are included to demonstrate what should be present in a production system. 6 merely shows a display of the current time, and so this should be improved as well.
Pressing 1 leads to the Configure Menu, which currently only allows the current time to be set:

Home Control System Version 1.09 (9 March 1997)

1) Set system clock

2) Return to main menu

Please enter a number :

Pressing 1 here gives a series of prompts to enter the time:

Home Control System Version 1.09 (9 March 1997) Set system clock Year: 1997

Month: 3 Dau of month: 9 Hours: 10 Minutes: 37 Seconds: 22

Pressing 2 at the main menu allows you to control a device immediately. As only one device is implemented is this system, only the immersion heater can be controlled.

Home Control System

Version 1.09 (9 March 1997)

Control device now

- Central heating 1)
- 2)
- Outside lights Ground floor lights Ground floor appliances First floor lights First floor appliances 3) 4)
- 5)
- 6)
- 7) Immersion heater
- 8) Other electrical devices
- 9) Return to main menu

Please enter a number :

If a number other than 7 is pressed, a message is displayed saying that there is only one device controllable. If 7 is pressed, the user is asked whether they want to turn the device on, off, or proportionally control it. In this example, they have pressed 3 for proportional control, and so are prompted for a value. At present, this value is sent directly to the device, but the software could be modified to accept it as a percentage or as a temperature, for example.

Device control:

```
    Device off
    Device on
    Proportional control
```

Please enter a number : 3 Value to send to device: 50

Option 3 from the main menu allows a timed event to be set. At present, the software will only support one event to occur in the next 24 hours. It brings up the same menu as for control timed event, so that the device can be selected. Once it has been selected, the system asks for the time and setting for that device.

Home Control System

Version 1.09 (9 March 1997)

Set timed event

Hours: 18 Minutes: 00 Seconds: 00 Device control:

Device off
 Device on
 Proportional control

Please enter a number : 3 Value to send to device: 25

After this, the system displays the main menu again. Option 7 on the main menu would hang up a modem if one were connected, as it sends +++ to enter modem command mode, and then ATH to hang up the telephone line.

## **Evaluation**

In its current form, the system does work, but to produce a system for mass production would still need a lot of work. In most areas, the hardware that has been built is sufficient for production, but the software needs considerable improvement. Most of the limitations that currently exist in the system exist because the software has been written to demonstrate the hardware, and show what it could do in a production system. Many weeks or months could be spent improving the software to bring the system up to a marketable product. In particular, much needed features include support for modems, which I was not able to include because it needed two telephone lines for testing, which were not available and would have generate large bills in the process. The system should also have password protection, so that only the owner of the house can access the system, and support for more than one timed event. The hardware is capable of setting approximately 2,000 timed events which can be set up to 99 years ahead, but there was no time to implement this in the software.

The microprocessor system itself seems to be quite reliable – it was left on overnight, and was still running in the morning. This is a necessity in a system that it intending to be left running for long periods. Also, if the system does crash while the householder is away, it may leave safety critical devices on, such as an oven or an electric fire. If it has severely crashed, it may not come back on line, and so the householder would not be able to turn these devices off. No evidence was found that this would happen, and if it did because of power failure the power on reset should clear any problems. A useful addition to the system would be a watchdog timer chip, which has to be accessed by the system every few seconds. If this is not done, the watchdog timer will decide the system has crashed and assert the master reset line.

The emulated EPROM was not perfectly reliable, and occasionally did not write a value properly. After investigation, it seems that the most likely cause was the 1.8m cable which connected the microprocessor board to the parallel port of the computer. As the signals travelling along this cable are quite fast, they start to deteriorate after a short distance. This would not matter in a production system, as the emulated EPROM would have to be replaced with real EPROMs or mask programmed ROMs to ensure the program stayed intact when power was removed.

The system occupies a large amount of board area, which would ideally be reduced in a production system. This could be done by using 16 bit wide RAM and ROM, and employing a processor that contains some on-chip peripherals, such as the Motorola 68300 series. The large board area which contains just wiring could be significantly reduced by building the system on a four or six layer PCB. As the ROM would be real ROM, there would be no need for the many tristates used in the EPROM emulator.

The data link worked reasonably well, although it was occasionally subject to interference. This is probably because the transmitters are driven by the output of a logic gate. Ideally, there should be some form of power amplifier to boost the signal before it is transmitted. The receiver could also be improved, because it currently has a fixed gain. If the transmitted signal varies in strength, the receiver picks up these variations and this may cause the logic output signal to be lost when the strength is low. This could be improved by adding an automatic gain control to more greatly amplify weak signals. This would have to be very carefully designed to ensure that it discriminated between noise and signal.

Occasionally the data link would get very noisy and lose the signal altogether. The output signal could be changed by moving different metal items above the breadboard. This seems to have been due to the RF signals being generated interfering with other parts of the circuit, possibly creating a feedback loop. The metal objects absorb the electromagnetic radiation produced, and so affect the circuit. This effect could probably have been eliminated by building the transmitters and receivers in separate metal boxes.

The data link was evaluated numerically by passing a square wave through in each direction, and determining the maximum frequency of square wave that could be resolved. On the 10 kHz carrier, the communications channel could handle frequencies from 0.1 to 80 Hz, while on the 100 kHz channel, it could handle from 0.1 to 2500 Hz. On both square wave outputs, there was a blurred rising edge of the square wave, and it was this that limited the bandwidth. The most likely cause of this is a delay in the transmission oscillator starting up, in which the output level is unstable. This gets transmitted through the various filters and amplifiers and is converted to a blur on the logic output. Careful filtering would be able to reduce this. As it is, the PIC does not appear to suffer a problem with this.

As stated previously, if this were a production version, the data link would use a direct mains connection to avoid the filtering effect of power transformers. If direct mains access were possible in this project, I would probably have investigated one of the mains carrier transceiver ICs designed for this purpose, such as the National Semiconductor LM1893. As it is, the system being used for the data link could be modified for mains use, and would probably work reasonably well if the improvements mentioned above were implemented. Mains is a much more noisy medium than a length of wire, so sharper filtering would have to be used.

The PICs at each end of the data link seemed to be working reasonably well, although they were occasionally susceptible to noise introduced in the data link. This could be reduced or even eliminated from a digital point of view by adding error correction to their software. This system is similar to that used on CD players to ignore scratches, and involves sending more data than is required, so that the receiving system can detect if there is an error in it, and reconstruct the original data packet from the extra information.

In summary, the system worked reasonably well for what it did, and showed that the hardware was working and sufficient for the task, but the software needs considerable refinement if this were to be a marketable product. The limitations of no direct mains access meant that the data link was different to that would be used in a production system, and this would need modification if this were to be produced commercially. A mains link is much more convenient, because it does not need extra wiring around the home.

## Photographs of project

The microprocessor system



Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

#### Non-functional mains data link circuit

Wire data link circuit (both ends) and remote module logic board

## **Appendix A**

# Excerpts from 'M68000 Microprocessor User's Manual' (copyright Motorola Corporation)





| Functi | ion Code ( | Output |                       |
|--------|------------|--------|-----------------------|
| FC2    | FC1        | FC0    | Address Space Type    |
| Low    | Low        | Low    | (Undefined, Reserved) |
| Low    | Low        | High   | User Data             |
| Low    | High       | Low    | User Program          |
| Low    | High       | High   | (Undefined, Reserved) |
| High   | Low        | Low    | (Undefined, Reserved) |
| High   | Low        | High   | Supervisor Data       |
| High   | High       | Low    | Supervisor Program    |
| High   | High       | High   | CPU Space             |

#### Table 3-3. Function Code Outputs

Bitmap removed to save space Copy available from http://www.mot.com Bitmap removed to save space Copy available from http://www.mot.com

Bitmap removed to save space Copy available from http://www.mot.com

| Vectors Numbers |                     | Address     |     | · <b>-</b>         |                                       |
|-----------------|---------------------|-------------|-----|--------------------|---------------------------------------|
| Hex             | Decimal             | Dec         | Hex | Space <sup>6</sup> | Assignment                            |
| 0               | ٥                   | C           | 000 | SP                 | Reset: Indial SSP <sup>2</sup>        |
| 1               | 1                   | 4           | 004 | SP                 | Resel: Initial PC <sup>2</sup>        |
| 2               | 2                   | 8           | 008 | SD                 | Bus Error                             |
| 3               | Э                   | 12          | 00C | SD                 | Address Error                         |
| 4               | 4                   | 16          | 010 | SD                 | Regal Instruction                     |
| Ş               | 5                   | 20          | 014 | SC                 | Zero Divide                           |
| 6               | 6                   | 24          | 018 | SD                 | CHK Instruction                       |
| 7               | 7                   | 28          | 010 | ŞD                 | TRAPY Instruction                     |
| ô               | 5                   | 32          | 020 | SD                 | Privilege Violation                   |
| ·               | . 9                 | 36          | 024 | SD                 | Trace                                 |
| A               | 10                  | 40          | 028 | ŞD                 | Line 1010 Emulator                    |
| 6               | 11                  | 44          | 02C | SD                 | Line 1111 Emulator                    |
| ç               | 121                 | 48          | 030 | SD                 | (Unassigned, Reserved)                |
| D               | , 13 <sup>1</sup> . | 52          | 034 | SD                 | (Unassigned, Reserved)                |
| E               | 14                  | <b>\$</b> 6 | 038 | SÐ                 | Forma: Error <sup>5</sup>             |
| F               | 15                  | 60          | 03C | SD                 | Uninitialized Interrupt Vector        |
| 10 17           | 16 23 <sup>1</sup>  | 64          | 040 | SD                 | (Unassigned, Reserved)                |
|                 |                     | 92          | 05C |                    |                                       |
| 18              | 24                  | 96          | 060 | SO                 | Spurinus Interrupt <sup>3</sup>       |
| 19              | 25                  | 100         | 064 | SƏ                 | Level 1 Interrupt Autovector          |
| 1A              | 26                  | 104         | 068 | SO                 | Level 2 Interrupt Autovector          |
| ıВ              | 27                  | 108         | 06C | ุรอ                | Level 3 Interrupt Autovector          |
| 1C              | 28                  | 112         | 070 | SD                 | Level 4 Interrupt Autovector          |
| 1D              | 29                  | 116         | 074 | SD                 | Level 5 Interrupt Autovector          |
| 1E              | 30                  | 120         | 078 | 50                 | Level 6 Interrupt Autovector          |
| 1F              | 31                  | 124         | 07C | SÐ                 | Level 7 Interrupt Autovector          |
| 20–2F           | 32-47               | 128         | 090 | \$D                | TRAP Instruction Vectors <sup>4</sup> |
|                 |                     | 198         | OBC |                    | —                                     |
| 30 3Ë           | 4863 <sup>1</sup>   | 192         | 000 | SD                 | (Unassigned, Reserved)                |
|                 |                     | 255         | OFF |                    |                                       |
| 40FF            | 64 255              | 256         | 100 | <u>\$</u> D        | User Interrupt Vectors                |
|                 |                     | 1020        | 3FC |                    | I —                                   |

Table 6-2. Exception Vector Assignment

NOTES:

- Vector numbers 12, 13, 16–23, and 48–63 are reserved for future enhancements by Motorola. No user peripheral devices shou'd be assigned these numbers.
- Reset vector (0) requires four words, unlike the other vectors which only require two words, and is located in the supervisor program space.
- The spurious interrupt vector is taken when there is a bus error indication during interrupt processing.
- TRAP #n uses vector humber 32+ n.
- MC68010 only. This vector is unessigned, reserved on the MC68000 and MC68008.
- SP denotes supervisor program space, and SD denotes supervisor data space.

## **Appendix B**

#### Main program

#### INCLUDE x68.defs

| trap_code | е                  | EQU                  | \$200      |   |         |       |         |           |       |
|-----------|--------------------|----------------------|------------|---|---------|-------|---------|-----------|-------|
| interrup  | t_code             | EQU                  | \$400      |   |         |       |         |           |       |
|           | INCLUDE<br>INCLUDE | x68.excs<br>x68.ints | s<br>serv4 |   |         |       |         |           |       |
| (         | ORG                | \$800                |            | * | base of | ROM   | after   | exception | table |
| start     |                    |                      |            |   |         |       |         |           |       |
| ]         | BRA                | main_ini             | t          | * | main in | itia  | lisatio | on        |       |
| start_in: | it                 |                      |            |   |         |       |         |           |       |
| ]         | BSR                | serial_i             | nit        | * | initial | ise : | serial  | system    |       |
| ]         | BSR                | pia_init             |            | * | initial | ise : | PIA     |           |       |
| ]         | BSR                | rtc_init             |            | * | initial | ise d | clock   |           |       |
| ]         | BSR                | via_init             |            | * | set VIA | to t  | talk to | D PIC     |       |
| ]         | BSR                | program_             | init       |   |         |       |         |           |       |

#### main\_menu

|          | MOVEQ    | #FF,D0                  |   |                                   |
|----------|----------|-------------------------|---|-----------------------------------|
|          | BSR      | serial_putc             | * | clear the terminal screen         |
|          | LEA      | banstrtbl,A1            | * | point to table of string pointers |
|          | BSR      | send_stringtable        | * | for banner, and send              |
|          | LEA      | mmstrtbl,Al             | * | point to table of string pointers |
|          | BSR      | send_stringtable        | * | for main menu, and send           |
|          | MOVEQ    | #`7′,D1                 | * | maximum number to accept          |
|          | BSR      | num_wait                | * | wait for a character              |
|          | MOVE.L   | D0,D2                   |   |                                   |
|          | MOVE.W   | #\$8000,D1              | * | provide a small delay so that the |
| main_mer | u_char_c | lelay                   | * | character can be seen on terminal |
|          | DBF      | D1,main_menu_char_delay |   |                                   |
|          | MOVEQ    | #FF,D0                  |   |                                   |
|          | BSR      | serial_putc             | * | clear screen                      |
|          | SUB.B    | #`1′,D2                 | * | convert ASCII number into         |
|          | CMP.B    | #0,D2                   | * | binary                            |
|          | BEQ      | system_config           |   |                                   |
|          | CMP.B    | #1,D2                   |   |                                   |
|          | BEQ      | control_now             |   |                                   |
|          | CMP.B    | #2,D2                   |   |                                   |
|          | BEQ      | set_event               |   |                                   |
|          | CMP.B    | #5,D2                   |   |                                   |
|          | BEQ      | rtc_showtime            |   |                                   |
|          | CMP.B    | #6,D2                   |   |                                   |
|          | BEQ      | quit                    |   |                                   |
|          | BRA      | main_menu               |   |                                   |
| quit     |          |                         |   |                                   |
|          | LEA      | modem_cmdmode,A0        | * | pointer to modem wakeup string    |
|          | BSR      | send_string             |   |                                   |
|          | MOVEQ    | #5,D1                   |   |                                   |

quit\_loop1 MOVE.L #\$FFFF,D0 \* Effectively a delay loop value \* of \$5FFFF quit\_loop2 \* wait for a seconds until modem DBF D0,quit\_loop2 D1,quit\_loop1 DBF \* responds LEA.1 modem\_hangup,A0 BSR send\_string \* send hangup command quit\_waitfornodcd MOVE.B ACIA\_SR,D0 \* get status register \* is DCD bit high BTST #2,D0 \* if not wait until it is BEQ quit\_waitfornodcd D0CLR quit\_endloop ADDQ #1,D0 BRA quit\_endloop system\_config MOVEQ #FF,D0 BSR serial\_putc \* clear the terminal screen \* point to table of string pointers banstrtbl,A1 LEA \* for banner, and send send\_stringtable BSR \* point to table of string pointers configstrtbl,A1 LEA \* for config menu, and send send\_stringtable BSR MOVE.B #`2',D1 \* maximum number to accept \* get key character BSR num\_wait MOVE.L D0,D2 MOVE.W #\$8000,D1 \* provide a small delay so that the \* character can be seen on terminal system\_config\_char\_delay D1,system\_config\_char\_delay DBF MOVEQ #FF,D0 BSR serial\_putc \* clear screen SUB.B #`1',D2 \* convert ASCII number into binary \* if 1 pressed, set time CMP.B #0,D2 BEQ rtc\_settime CMP.B #1,D2 \* if 2 pressed, go to main menu main\_menu BEO BRA system\_config \* wait for a number to be entered num\_wait \* must be 1 digit, between 1 and D1 \* get character BSR serial\_getc \* if no char ready, wait for one BEQ num\_wait CMP.B #`1′,D0 \* is it a number 1-2 \* if not wait for a number BLTnum\_wait CMP.B D1,D0 num\_wait BGT BSR serial\_putc \* send the character RTS rtc\_settime #FF,D0 MOVEQ serial\_putc \* clear the terminal screen BSR \* point to table of string pointers LEA banstrtbl,A1 \* print banner BSR send\_stringtable LEA clksetstrtbl,A1 \* print title BSR send\_stringtable LEA rtcsettbl,A3 \* table pointing to prompt and regs

rtc\_settime\_loop

MOVEQ #CR,D0 serial\_putc BSR MOVEQ #LF,D0 BSR serial\_putc MOVEA.L (A3) + , A2\* get prompt ptr MOVE.W (A3) + , D3\* get min value MOVE.W (A3) + , D4\* get max value BSR get\_bcd\_number \* RTC register MOVE.W (A3)+,D1 MOVE.L D0,D2 \* value to store MOVE.W #Hardware\_RTC\_Write,D0 \* call OS routine TRAP #15 MOVE.L (A3),D0 \* get next address D0 \* is it zero? TST BNE rtc\_settime\_loop \* if not, get next value BRA system\_config get\_bcd\_number MOVEA.L A2,A0 BSR send\_string \* print prompt get\_line \* read line BSR BSR.S bcdval\_line \* extract BCD data from line CMP.W D3,D0 BLT.S get\_bcd\_number\_again \* is it past max value CMP.W D4,D0 BGT.S get\_bcd\_number\_again RTS get\_bcd\_number\_again cursorup,A0 LEA BSR send\_string wipestr,A0 LEA BSR send\_string BRA get\_bcd\_number bcdval\_line \* convert string pointed to by A0 MOVEM.L D1/A0,-(A7) \* to BCD number \* get character MOVE.B (A0)+,D1CMP.B #`0′,D1 \* check it is a valid digit BLT.S bcdval\_line\_err CMP.B #'9',D1 BGT.S bcdval\_line\_err SUB.B #`0′,D1 \* convert to binary digit LSL.W #4,D1 \* make into MSB MOVE.W D1,D0 \* put in D0 MOVE.B (A0)+,D1 \* get character CMP.B #32,D1 BLT.S bcdval\_line\_singdig \* check it is a valid digit CMP.B #`0',D1 BLT.S bcdval\_line\_err #`9',D1 CMP.B BGT.S bcdval\_line\_err SUB.B #`0′,D1 \* convert to binary digit \* put in LSB of D0 OR.W D1,D0 AND.W #\$FF,D0 MOVEM.L (A7) + , D1/A0\* return value in D0 RTS bcdval\_line\_err \* return invalid result

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

MOVEO

#-1,D0

MOVEM.L (A7) + , D1/A0RTS \* if second digit is ctrl char, bcdval\_line\_singdig LSR.W \* treat as 1 digit #4,D0 AND.W #\$0F,D0 MOVEM.L (A7)+,D1/A0 RTS control\_now MOVEQ #FF,D0 BSR serial\_putc LEA banstrtbl,A1 \* clear the terminal screen \* point to table of string pointers \* for banner, and send send\_stringtable BSR \* point to table of string pointers LEA connowstrtbl,A1 send\_stringtable BSR \* for config menu, and send MOVE.B #`9',D1 \* maximum number to accept \* get key character BSR num\_wait MOVE.L D0,D2 \* provide a small delay so that the MOVE.W #\$8000,D1 control\_now\_char\_delay \* character can be seen on terminal DBF D1, control\_now\_char\_delay MOVEQ #FF,D0 BSR serial\_putc \* clear screen SUB.B #`1',D2 \* convert ASCII number into binary CMP.B #8,D2 \* if 9 pressed, go to main menu BEO main menu CMP.B #7,D2 \* if 8 pressed, get number of other control\_now\_other\_device \* device and control it BEO CMP.B #6,D2 \* if 7 pressed, get number of heater BEQ control\_now\_heater\_device \* and control it not\_implemented \* if other number, say isn't BRA \* implemented control\_now\_other\_device BSR other\_device BRA control\_device control\_now\_heater\_device BSR heater\_device BRA control\_device not\_implemented MOVEQ #FF,D0 BSR serial\_putc LEA banstrtbl,A1 BSR send\_stringtable \* clear the terminal screen \* point to table of string pointers \* for banner, and send \* point to table of string pointers LEA notimpstrtbl,A1 send\_stringtable \* for message, and send BSR not\_implemented\_wait serial\_getc BSR not\_implemented\_wait \* wait for key to be pressed BEO main\_menu BRA other\_device MOVEQ #FF,D0 \* clear the terminal screen BSR serial\_putc \* point to table of string pointers LEA banstrtbl,A1 \* for banner, and send BSR send\_stringtable

CLR D3 \* minimum number MOVE.W #\$99,D4 \* maximum number \* get prompt LEA od1,A2 \* get the number - should be 0-255, BSR get\_bcd\_number \* but is simpler if get\_bcd is used \* therefore only 0-99 available \* convert to hex number in D0 hex\_to\_dec BSR RTS \* return heater\_device MOVE.W heater\_dev\_no,D0\* read heater device number RTS control\_device \* keep device number safe MOVE.L D0,D6 MOVEQ #\$67,D7 \* code for control now \* find out what to set to BRA set\_event\_get\_setting control\_device\_now \* D6=device number, D0=setting MOVE.L D6,D1 \* put number in D1 EXG.L D0,D1 \* swap number and setting \* send command packet BSR send\_PIC\_command \* then go to main menu BRA main\_menu set\_event MOVEQ #FF,D0 BSR serial\_putc LEA banstrtbl,A1 \* clear the terminal screen \* point to table of string pointers send\_stringtable \* for banner, and send BSR \* point to table of string pointers LEA setevstrtbl,A1 send\_stringtable BSR \* for config menu, and send MOVE.B #`9',D1 \* maximum number to accept \* get key character BSR num\_wait MOVE.L D0,D2 MOVE.W #\$8000,D1 \* provide a small delay so that the \* character can be seen on terminal set\_event\_char\_delay DBF D1,set\_event\_char\_delay MOVEQ #FF,D0 BSR serial\_putc \* clear screen \* convert ASCII number into binary SUB.B #`1',D2 CMP.B #8,D2 \* if 9 pressed, go to main menu BEO main\_menu CMP.B #7,D2 \* if 8 pressed, get number of other set\_event\_other\_device \* device and control it BEQ CMP.B #6,D2 \* if 7 pressed, get number of heater set\_event\_heater\_device \* and control it BEO \* if other number, say isn't BRA not\_implemented \* implemented set\_event\_other\_device BSR other\_device BRA set\_event\_get\_details set\_event\_heater\_device BSR heater\_device BRA set\_event\_get\_details set\_event\_get\_details

MOVE.L D0,D2

#RTC\_DEVICE\_ALRM,D1 \* device number byte in CMOS MOVEQ MOVE.W #Hardware\_RTC\_Write,D0 \* write it TRAP #15 MOVEQ #FF, D0 serial\_putc banstrtbl,Al send\_stringtable setdetstrtbl,A1 send\_stringtable BSR \* clear the terminal screen \* point to table of string pointers LEA BSR \* print banner LEA BSR \* print title setdettbl,A3 \* table pointing to prompt and regs LEA set\_event\_get\_details\_loop MOVEQ #CR,D0 BSR serial\_putc MOVEQ #LF,D0 BSR serial\_putc MOVEA.L (A3)+,A2 \* get prompt ptr \* get min value MOVE.W (A3)+,D3 MOVE.W (A3)+,D4 \* get max value BSR get\_bcd\_number (A3)+,D1 \* RTC register MOVE.W MOVE.L D0,D2 \* value to store MOVE.W #Hardware\_RTC\_Write,D0 \* call OS routine TRAP #15 MOVE.L (A3),D0 \* get next address \* is it zero? D0 TST \* if not, get next value BNE set\_event\_get\_details\_loop set\_event\_get\_setting LEA newline,A0 \* print newline BSR send\_string LEA devctrlstrtbl,A1 BSR send\_stringtable \* print menu MOVE.B #`3',D1 \* maximum number to accept BSR num\_wait \* get key character MOVE.L D0,D2 MOVE.W #\$8000,D1 \* provide a small delay so that the set\_event\_get\_details\_char\_delay \* character can be seen on terminal DBF D1, set\_event\_get\_details\_char\_delay SUB.B #`1',D2 \* convert ASCII number into binary CMP.B #0,D2 \* if 1 pressed, turn off BEQ set\_event\_gd\_off CMP.B \* if 8 pressed, turn on #1,D2 BEQ set\_event\_gd\_on \* here 2 was pressed, so get number LEA newline,A1 MOVEA.L A1,A0 BSR send\_string value,A2 LEA MOVEQ #0,D3 MOVE.W #\$99,D4 BSR get\_bcd\_number CMP #\$67,D7 \* control immediately? control\_device\_now BEO set\_event\_store\_data MOVEO #RTC\_DATA\_VALUE,D1 MOVE.L D0,D2

MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 set\_event\_enable\_irq #RTC\_STATUS\_B,D1 \* RTC register B MOVEQ MOVE.W #Hardware\_RTC\_Read,D0 \* read it TRAP #15 BSET #5,D0 \* set alarm interrupt enable MOVE.L D0,D2 #RTC\_STATUS\_B,D1 MOVEQ \* RTC register B MOVE.W #Hardware\_RTC\_Write,D0 \* write it TRAP #15 main\_menu BRA set\_event\_gd\_off MOVEQ #0,D0 set\_event\_store\_data BRA set\_event\_gd\_on MOVE.W #\$99,D0 BRA set\_event\_store\_data send\_PIC\_command \* D0 = device number, D1 = value BSR send\_PIC\_byte \* send D0 MOVE.L D1,D0 BSR send\_PIC\_byte \* send D1 MOVE.W #\$FF,D0 \* send end of packet code send\_PIC\_byte BSR RTS send\_PIC\_byte \* write value to PIC through VIA MOVE.B D0,VIA\_DRA \* delay value MOVE.W #\$FFF,D7 send\_PIC\_byte\_loop \* delay waiting for IRQ D7,send\_PIC\_byte\_loop DBF RTS \* Initialisation section for main program main\_init MOVE.W #\$0,SR \* clear status register - go into \* user mode MOVEA.L #\$43F00,A7 \* set user stack pointer to \* sensible RAM address \* return - can't use BSR/RTS because BRA start\_init \* stacks have been swapped pia\_init \* access DDRA, enable CA1 MOVE.B #\$31,PIA\_CRA \* and system interrupts MOVE.B #\$FF,PIA\_DDRA \* make PIA Port A outputs \* set PB0-3 outputs, MOVE.B #\$00,PIA\_CRB \* MOVE.B #\$0F,PIA\_DDRB PB4-7 inputs MOVE.B #\$04,PIA\_CRB \* select Peripheral Reg B MOVE.B #\$F9,PIA\_PRB \* other bits high, R-/W high, \* DS, AS low, /CS high RTS \* return

serial\_init MOVE.B DIN,D0 \* read input port AND.B #\$7F,D0 \* mask off other bits \* take copy of D0 MOVE.B D0,D1 \* mask only bps selector bits AND.B #\$7,D0 MOVE.B D0,SER\_BPS \* set serial data rate MOVE.B #3,ACIA\_CR \* Initialise 6850 \* select divide by 64 MOVEO #2,D2 #3,D1 \* is bit 3 of DIP switch on? BTST BNE.S serial\_init\_setdiv16 \* if so select div by 16 serial\_init\_cont1 AND.B #\$70,D1 \* get word select bits LSR.B #2,D1 \* shift into correct position for \* ACIA control register \* OR with D2 -> D2 OR.B D1.D2 \* CR7-5 = 101, RTS on, enable \*OR.B #\$00,D2 \* receive and transmit IRQs MOVE.B D2,ACIA\_CR \* set control register MOVE.B D2, SERIAL\_CONFIG \* Reset buffer pointers CLR.W SERIAL\_RX\_INPTR CLR.W SERIAL\_RX\_OUTPTR CLR.W SERIAL\_TX\_INPTR CLR.W SERIAL\_TX\_OUTPTR \* return from subroutine RTS serial\_init\_setdiv16 MOVEQ #1,D2 \* select divide by 16 BRA serial\_init\_cont1 rtc\_init MOVEQ #RTC\_STATUS\_D,D1 \* RTC status register D MOVE.W #Hardware\_RTC\_Read,D0 \* read it TRAP #15 MOVE.L D0,D3 \* Preserve result \* RTC status register A MOVEQ #RTC\_STATUS\_A,D1 \* clear it MOVEQ #\$00,D2 MOVE.W #Hardware\_RTC\_Write,D0 \* call OS routine TRAP #15 MOVEQ #RTC\_STATUS\_C,D1 \* RTC status register C \* reset interrupt flags MOVE.W #Hardware\_RTC\_Read,D0 \* call OS routine TRAP #15 MOVEQ #RTC\_STATUS\_B,D1 \* RTC status register B \* set Update Interrupt Enabled MOVEQ #\$10,D2 MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 #7,D3 \* is bit 7 of reg D (VRT) set? BTST \* if so, don't bother to reset time BNE rtc\_init\_end MOVEQ #RTC\_SECS,D1 \* on startup, set time and date \* to 00:00:00 on 1st January 1997 MOVEQ #\$00,D2 MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 MOVEQ #RTC\_MINS,D1 MOVEO #\$00,D2 MOVE.W #Hardware\_RTC\_Write,D0

TRAP #15 MOVEQ #RTC\_HRS,D1 #\$00,D2 MOVEQ MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 MOVEQ #RTC\_DAY,D1 MOVEQ #\$1,D2 MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 MOVEQ #RTC\_DATE, D1 MOVEQ #\$1,D2 MOVE.W #Hardware\_RTC\_Write,D0 #15 TRAP MOVEQ #RTC\_MONTH,D1 MOVEQ #\$1,D2 MOVE.W #Hardware\_RTC\_Write,D0 #15 TRAP MOVEQ #RTC\_YEAR, D1 MOVE.b #\$97,D2 MOVE.W #Hardware\_RTC\_Write,D0 TRAP #15 rtc\_init\_end RTS via\_init \* VIA initialisation \* Make port A an input CLR.B VIA DDRA CLR.B VIA DDRB \* Make port B an input MOVE.B #%00001000,VIA\_PCR \* Select port A handshake mode \* Enable CB1 interrupt MOVE.B #%10010000,VIA\_IER RTS \* Return program\_init MOVE.L #TF\_BLK, TF\_START \* initialise timeframe list MOVE.L #TF\_BLK, TF\_END RTS \* Miscellaneous general purpose subroutines serial\_putc #1,ACIA\_SR \* is port 1 ready for a character? BTST \* if not, wait for it serial\_putc BEO \* out it goes. MOVE.B D0,ACIA\_TR RTS serial\_getc \* is character ready? #0,ACIA\_SR BTST \* if not, return Zero status BEQ.S serial\_getc\_ret \* else get the character MOVE.B ACIA RR,D0 \* zero out the high bit AND.B #\$7F,D0 serial\_getc\_ret RTS send\_string \* Send serial string pointed to by A0 MOVE.B (A0) + , D0\* get next byte TST.B D0 BEO send\_string\_return \* send it BSR serial\_putc \* if not do next one BRA send\_string

send\_string\_return RTS send\_bcd\_number MOVE.L D1,-(A7) MOVE.L D0,D1 #4,D0 LSR AND #\$0F,D0 ADD.B #`0',D0 BSR serial\_putc MOVE.L D1,D0 #\$0F,D0 AND ADD.B #'0',D0 serial\_putc BSR MOVE.L (A7)+,D1 RTS send\_stringtable \* send an whole string table through \* the serial port \* on entry A1 points to table MOVEM.L D1/A0,-(A7) CLR D1 send\_stringtable\_loop MOVEA.L (A1,D1),A0 \* get address from table CMPA #0,A0 BEQ send\_stringtable\_end \* if zero, end procedure \* if not, send string BSR send string #4,D1 ADDO BRA send\_stringtable\_loop send\_stringtable\_end MOVEM.L (A7) + , D1/A0\* restore registers \* return RTS get\_line \* read a line, terminated by control \* character from serial port \* buffer to store string SERIAL\_WORKSPACE,A0 LEA get\_line\_loop BSR serial\_getc \* get character BEO get\_line\_loop CMP.B #127,D0 \* is it delete/backspace BEQ get\_line\_del \* if so delete character CMP.B #8,D0 get\_line\_del BEO \* otherwise echo it to the terminal BSR serial\_putc MOVE.B D0,(A0)+ CMP.B #31,D0 \* is it control char? \* if not, get next get\_line\_loop BGT \* replace control char with zero MOVE.B #0,-1(A0) SERIAL\_WORKSPACE,A0 \* return start of string LEA RTS get\_line\_del SUBO #1,A0 \* delete previous char CMPA.L #SERIAL\_WORKSPACE,A0 \* is it before workspace \* if so, start again BLT.S get\_line MOVEQ #8,D0 \* backspace serial\_putc BSR MOVEQ #`',D0 \* overwrite last char BSR serial\_putc \* backspace MOVEO #8,D0

|          | BSR<br>BRA.S   | serial_putc<br>get line loop | * | de:<br>and | let<br>d c | te ch<br>delet | lara<br>le c | cter<br>har | on | terminal |
|----------|----------------|------------------------------|---|------------|------------|----------------|--------------|-------------|----|----------|
|          |                | 5 1                          |   |            |            |                |              |             |    |          |
| rtc_send | dtime          |                              |   |            |            |                |              |             |    |          |
|          | LEA            | tsec, AU                     |   |            |            |                |              |             |    |          |
|          | BSR<br>MOUTE D | send_string                  |   |            |            |                |              |             |    |          |
|          | MOVE.B         | RIC_SC_SECS, DU              |   |            |            |                |              |             |    |          |
|          | BSR            | send_bcd_number              |   |            |            |                |              |             |    |          |
|          | LLA            | newline, Au                  |   |            |            |                |              |             |    |          |
|          | BSK            | tmin A0                      |   |            |            |                |              |             |    |          |
|          | ЦЕА<br>ПСП     | cond string                  |   |            |            |                |              |             |    |          |
|          | DOK<br>MOVE D  | DTC CC MING DO               |   |            |            |                |              |             |    |          |
|          |                | RIC_SC_MINS, DU              |   |            |            |                |              |             |    |          |
|          | DSR            | newline A0                   |   |            |            |                |              |             |    |          |
|          | DCD            | aond string                  |   |            |            |                |              |             |    |          |
|          | DSK<br>T E A   | thra AO                      |   |            |            |                |              |             |    |          |
|          | BGD            | cond string                  |   |            |            |                |              |             |    |          |
|          | MOVE B         |                              |   |            |            |                |              |             |    |          |
|          | BGD            | send had number              |   |            |            |                |              |             |    |          |
|          | LEA            | newline A0                   |   |            |            |                |              |             |    |          |
|          | BGD            | send string                  |   |            |            |                |              |             |    |          |
|          | LEA            | tday A0                      |   |            |            |                |              |             |    |          |
|          | BCB            | send string                  |   |            |            |                |              |             |    |          |
|          | MOVE B         | RTC SC DAY DO                |   |            |            |                |              |             |    |          |
|          | RSR            | send bod number              |   |            |            |                |              |             |    |          |
|          | LEA            | newline A0                   |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | LEA            | tdate A0                     |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | MOVE . B       | RTC SC DATE DO               |   |            |            |                |              |             |    |          |
|          | BSR            | send bcd number              |   |            |            |                |              |             |    |          |
|          | LEA            | newline.A0                   |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | LEA            | tmonth, A0                   |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | MOVE.B         | RTC SC MONTH, D0             |   |            |            |                |              |             |    |          |
|          | BSR            | send bcd number              |   |            |            |                |              |             |    |          |
|          | LEA            | newline,A0                   |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | LEA            | tvear,A0                     |   |            |            |                |              |             |    |          |
|          | BSR            | send string                  |   |            |            |                |              |             |    |          |
|          | MOVE.B         | RTC SC YEAR, D0              |   |            |            |                |              |             |    |          |
|          | BSR            | send_bcd_number              |   |            |            |                |              |             |    |          |
|          | LEA            | newline,A0                   |   |            |            |                |              |             |    |          |
|          | BSR            | send_string                  |   |            |            |                |              |             |    |          |
|          | RTS            |                              |   |            |            |                |              |             |    |          |
| rtc_show | wtime          |                              |   |            |            |                |              |             |    |          |
|          | MOVEQ          | #FF,D0                       |   |            |            |                |              |             |    |          |
|          | BSR            | serial_putc                  |   |            |            |                |              |             |    |          |
| rtc_show | wloop          |                              |   |            |            |                |              |             |    |          |
|          | BSR            | rtc_sendtime                 |   |            |            |                |              |             |    |          |
|          | MOVE.W         | #\$1000,D0                   |   |            |            |                |              |             |    |          |
| rl       |                |                              |   |            |            |                |              |             |    |          |
|          | DBF            | D0,rl                        |   |            |            |                |              |             |    |          |
|          | lea            | up,A0                        |   |            |            |                |              |             |    |          |
|          | BSR            | send_string                  |   |            |            |                |              |             |    |          |
|          | BSR            | serial_getc                  |   |            |            |                |              |             |    |          |
|          | BNE            | main_menu                    |   |            |            |                |              |             |    |          |
|          | BRA            | rtc_showloop                 |   |            |            |                |              |             |    |          |

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

hex\_to\_dec \* D0 = BCD value MOVE.W D0,D1 \* D1 = decimal result AND.W #\$F,D1 \* mask off high bits \* mask off low bits of D0 AND.W #\$F0,D0 LSR.W #4,D0 \* make into nybble \* D2 is temp reg MOVE.L D0,D2 \* D0 \* 8 LSL.W #3,D2 \* D0 \* 8 + D0 ADD.W D0,D2 \* D0 \* 8 + D0 + D0 = 10 D0 D0,D2 ADD.W D1,D2 \* add to low nybble and ret in D0 ADD.W MOVE.W D2,D0 RTS \* Data and text messages heater\_dev\_no \$0007 \* PIC id number for heater DC.W DCB.W 0,0 tb DC.B 'Home Control System', LF, CR, LF, CR, 0 DCB.W 0,0 ver 'Version 1.10 (9 March 1997)', LF, CR, LF, CR, LF, CR, 0 DC.B DCB.W 0,0 \* Main menu options mm DC.B **`**1) Configure system', LF, CR, LF, CR, 0 mm1 Control appliance now', LF, CR, LF, CR, 0 mm2 DC.B **`**2) mm3 DC.B **`**3) Set timed event', LF, CR, LF, CR, 0 DC.B **`**4) List current timed events', LF, CR, LF, CR, 0 mm4 DC.B **`**5) Clear timed event', LF, CR, LF, CR, 0 mm5 ттб DC.B **`**6) View current conditions', LF, CR, LF, CR, 0 DC.B **`**7) mm7 Goodbye', LF, CR, LF, CR, 0 DC.B LF,CR,0 gap plent DC.B 'Please enter a number : ',0 DC.W 0 banstrtbl DC.L tb DC.L ver DC.L 0 mmstrtbl DC.L mm1 DC.L mm2 DC.L mm 3 DC.L mm4 DC.L mm5 DC.L ттб DC.L mm7 DC.L gap DC.L plent DC.L 0 CS Set system clock', LF, CR, LF, CR, 0 cs1 DC.B **`**1)

DC.L 0

| cs2      | DC.B<br>DC.L | <pre>`2) Return to main menu',LF,CR,LF,CR,0<br/>0</pre> |
|----------|--------------|---------------------------------------------------------|
| configs  | trtbl        |                                                         |
| <u> </u> | DC.L         | csl                                                     |
|          | DC.L         | cs2                                                     |
|          | DC.L         | qap                                                     |
|          | DC.L         | plent                                                   |
|          | DC.L         | 0                                                       |
| qC       |              |                                                         |
| sc1      | DC B         | 'Set system clock' LF CR 0                              |
| sc2      | DC B         | '' LF CR 0                                              |
| 562      | DC.W         | 0                                                       |
| ~]]-~~+~ |              |                                                         |
| CIRSELS. |              | scl                                                     |
|          | DC.L         |                                                         |
|          | DC.L         | 0                                                       |
|          | DC.L         | 0                                                       |
| modem_ci | ndmode       |                                                         |
|          | DC.B         | `+++',0                                                 |
| modem_ha | angup        |                                                         |
|          | DC.B         | ATH', CR, U                                             |
|          | dc.1         | 0                                                       |
| tsec     | DC.B         | Seconds: ',0                                            |
| tmin     | DC.B         | 'Minutes: ',0                                           |
| thrs     | DC.B         | 'Hours: ',0                                             |
| tday     | DC.B         | 'Day of week: ',0                                       |
| tdate    | DC.B         | 'Day of month: ',0                                      |
| tmonth   | DC.B         | 'Month: ',0                                             |
| tyear    | DC.B         | 'Year: 19',0                                            |
|          | DCB.W        | 0,0                                                     |
| rtcsett  | bl           |                                                         |
| 20000000 | DC.L         | tvear                                                   |
|          | DC.W         | \$00,\$99,RTC YEAR                                      |
|          | DC.L         | tmonth                                                  |
|          | DC.W         | \$01,\$12,RTC MONTH                                     |
|          | DC.L         | tdate                                                   |
|          | DC.W         | \$01,\$31,RTC DATE                                      |
|          | DC.L         | thrs                                                    |
|          | DC.W         | \$00,\$23,RTC_HRS                                       |
|          | DC.L         | tmin                                                    |
|          | DC.W         | \$00,\$59,RTC_MINS                                      |
|          | DC.L         | tsec                                                    |
|          | DC.W         | \$00,\$59,RTC_SECS                                      |
|          | DC.L         | 0                                                       |
|          | DC.W         | 0,0                                                     |
| cn       | DC.B         | 'Control device now', LF.CR.0                           |
| cns      | DC.B         | `'.LF.CR.LF.CR.0                                        |
| ct1      | DC.B         | 1) Central heating'.LF.CR.0                             |
| ct2      | DC.B         | '2) Outside lights' LF.CR.0                             |
| ct3      | DC.B         | '3) Ground floor lights'.LF.CR.0                        |
| ct4      | DC.B         | (4) Ground floor appliances' LF.CR.0                    |
| ct5      | DC.B         | '5) First floor lights' LF.CR.0                         |
| ct6      | DC.B         | '6) First floor appliances'.LF.CR.0                     |
| ct7      | DC.B         | '7) Immersion heater', LF, CR, 0                        |

| ct8<br>ct9 | DC.B<br>DC.B<br>DCB.W | `8)<br>`9)<br>0,0 | Other electrical devices',LF,CR,LF,CR,0<br>Return to main menu',LF,CR,LF,CR,0 |
|------------|-----------------------|-------------------|-------------------------------------------------------------------------------|
| aonnoua    | - w+ hl               |                   |                                                                               |
| connows    |                       | an                |                                                                               |
|            |                       | cng               |                                                                               |
|            |                       | chis              |                                                                               |
|            |                       | at 2              |                                                                               |
|            |                       | ct3               |                                                                               |
|            |                       | ct4               |                                                                               |
|            |                       | ct5               |                                                                               |
|            |                       | ct6               |                                                                               |
|            |                       | ct7               |                                                                               |
|            | DC.L                  | ct8               |                                                                               |
|            | DC.L                  | ct9               |                                                                               |
|            | DC.L                  | qap               |                                                                               |
|            | DC.L                  | plent             |                                                                               |
|            | DC.L                  | 0                 |                                                                               |
|            |                       |                   |                                                                               |
| se         | DC.B                  | `Set tim          | ned event',LF,CR,0                                                            |
| ses        | DC.B                  | ۱                 | ', LF, CR, LF, CR, 0                                                          |
|            | DCB.W                 | 0,0               |                                                                               |
|            |                       |                   |                                                                               |
| setevst    | ntbl<br>Da I          | <b>a a</b>        |                                                                               |
|            | DC.L                  | se                |                                                                               |
|            | DC.L                  | ses<br>at 1       |                                                                               |
|            |                       | at 2              |                                                                               |
|            |                       | ct2               |                                                                               |
|            |                       | ct4               |                                                                               |
|            |                       | ct5               |                                                                               |
|            |                       | ct6               |                                                                               |
|            | DC.L                  | ct7               |                                                                               |
|            | DC.L                  | ct8               |                                                                               |
|            | DC.L                  | ct9               |                                                                               |
|            | DC.L                  | qap               |                                                                               |
|            | DC.L                  | plent             |                                                                               |
|            | DC.L                  | 0                 |                                                                               |
|            |                       |                   |                                                                               |
|            | DCB.W                 | 0,0               |                                                                               |
| nil        | DC.B                  | 'This fu          | unction is not implemented in this version',LF,CR,0                           |
| ni2        | DC.B                  | `of the           | control software. Currently, only the', LF, CR, 0                             |
| ni3        | DC.B                  | 'immers:          | ion heater can be controlled.', LF, CR, LF, CR, 0                             |
| ni4        | DC.B                  | 'If this          | s system were being used commercially,',LF,CR,0                               |
| nib        | DC.B                  | `these :          | functions would be present and the software', LF, CR, 0                       |
| nib        | DC.B                  | 'would I          | be considerably refined.', LF, CR, LF, CR, U                                  |
| nıp        | DC.B                  | Press a           | any key to continue.', LF, CR, U                                              |
|            | DCB.W                 | 0.0               |                                                                               |
| notimps    | trtbl                 | -,-               |                                                                               |
| T          | DC.L                  | ni1               |                                                                               |
|            | DC.L                  | ni2               |                                                                               |
|            | DC.L                  | ni3               |                                                                               |
|            | DC.L                  | ni4               |                                                                               |
|            | DC.L                  | ni5               |                                                                               |
|            | DC.L                  | ni6               |                                                                               |
|            | DC.L                  | nip               |                                                                               |
|            | DC.L                  | 0                 |                                                                               |

|                         | DCB.W      | 0,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| od1                     | DC.B       | `Enter number of device to control: ',0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| setdetst                | rtbl       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.L       | se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                         | DC.L       | Ses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | DC.L       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| setdetth                | <b>5</b> 1 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.L       | thrs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                         | DC W       | \$00.\$23.RTC HRS ALRM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                         |            | tmin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                         | DC W       | SOO STO MINS ALRM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC W       | COC SEC RECENTER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                         | *DC T      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | *DC.L      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |            | \$00,\$99,\$0r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                         | DC.L       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.W       | 0,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| -l                      |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |            | Device control:/ IE OD IE OD 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| del                     | DC.B       | Device Control, ", LF, CR, LF, CR, U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| dc2                     | DC.B       | 1) Device off', LF, CR, U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ac3                     | DC.B       | 2) Device on', LF, CR, U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ac4                     | DC.B       | '3) Proportional control', LF, CR, U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                         | DCB.W      | 0,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| J <b>.</b> J .          |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| devetris                | STREAL     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.L       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.L       | dC2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | DC.L       | dc3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | DC.L       | dc4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | DC.L       | gap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         | DC.L       | plent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                         | DC.L       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| proptbl                 |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.L       | value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                         | DC.W       | \$00,\$99,\$0F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                         | DC.L       | 0,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| _                       |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| value                   | DC.B       | 'Value to send to device: ',0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                         | DCB.W      | 0,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| - ·                     | 50.5       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| newline                 | DC.B       | CR, LF, U                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                         | חמ ח       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| up                      | DC.B       | 27, [IA ,27, [IA ,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| wipestr                 | DCB B      | 79. \ '                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <u>-</u> _ <b>32 01</b> | DCB.B      | 79,8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                         | DC.B       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| cursorur                | C          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         | DC.B       | 27,`[1A',LF,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                         | END star   | st state in the state of the st |

#### Interrupt handling code

\* Interrupt service routines ORG \$70 \* PIA's interrupt vector DC.L pia\_int \$74 ORG \* VIA's interrupt vector DC.L via\_int ORG \$7C \* NMI handler DC.L memdump \* Centrally allocated code space ORG interrupt\_code \* general purpose return int\_return MOVEM.L (A7)+,ALLREGS \* restore regs RTE \* return \* Called on PIA interrupt pia\_int \* Preserve all registers on stack MOVEM.L ALLREGS, -(A7) \* Read PIA status register A MOVE.B PIA\_CRA,D0 \* Is IRQ A set BTST #7,D0 BNE rtc\_int \* its an RTC interrupt #6,D0 \* Is IRQ B set BTST \* its something else's interrupt NOP \* Read PIA status register A MOVE.B PIA\_CRB,D0 \* Is IRQ A set BTST #7,D0 \* its something else's interrupt NOP \* Is IRQ B set BTST #6,D0 NOP \* its something else's interrupt MOVEM.L (A7)+,ALLREGS RTE rtc\_int MOVE.L #Hardware\_RTC\_Read,D0 \* read the RTC to clear interrupt MOVE.B #RTC\_STATUS\_C,D1\* status register C TRAP #15 \* do it #5,D0 \* is it alarm interrupt? BTST rtc\_int\_alarm BNE #4,D0 rtc\_int\_softcopy \* is it update interrupt? BTST BNE MOVEM.L (A7)+, ALLREGS RTE \* Copy the RTC values into RAM rtc\_int\_softcopy MOVE.L #Hardware\_RTC\_Read,D0 \* read the RTC seconds \* second register MOVE.B #RTC\_SECS,D1 \* do it TRAP #15 MOVE.B D0,RTC\_SC\_SECS \* store in memory MOVE.L #Hardware\_RTC\_Read,D0 \* do the same for all the other MOVE.B #RTC\_SECS\_ALRM,D1 \* timing registers #15 TRAP MOVE.B D0,RTC\_SC\_SECS\_ALRM MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_MINS,D1 TRAP #15 MOVE.B D0,RTC\_SC\_MINS

MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_MINS\_ALRM,D1 TRAP #15 MOVE.B D0,RTC\_SC\_MINS\_ALRM MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_HRS,D1 #15 TRAP MOVE.B D0,RTC\_SC\_HRS MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_HRS\_ALRM,D1 TRAP #15 MOVE.B D0,RTC\_SC\_HRS\_ALRM MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_DAY,D1 TRAP #15 MOVE.B D0,RTC\_SC\_DAY MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_DATE,D1 #15 TRAP MOVE.B D0,RTC\_SC\_DATE MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_MONTH,D1 TRAP #15 MOVE.B D0,RTC\_SC\_MONTH MOVE.L #Hardware\_RTC\_Read,D0 MOVE.B #RTC\_YEAR,D1 TRAP #15 MOVE.B D0,RTC\_SC\_YEAR MOVEM.L (A7)+, ALLREGS RTE rtc\_int\_alarm MOVE.W #Hardware\_RTC\_Read,D0 \* read status register MOVEQ #RTC\_STATUS\_B,D1 TRAP #15 BCLR #5,D0 \* clear alarm bit - disable MOVE.L D0,D2 \* alarm interrupts MOVE.W #Hardware\_RTC\_Write,D0 \* write status register MOVEQ #RTC\_STATUS\_B,D1 TRAP #15 MOVE.W #Hardware\_RTC\_Read,D0 \* read device number MOVEQ #RTC DEVICE ALRM, D1 TRAP #15 MOVE.L D0,D7 MOVE.W #Hardware RTC Read,D0 \* read setting MOVEQ #RTC\_DATA\_VALUE, D1 TRAP #15 \* now D7 = device to write \* and D0 = value to write to it MOVE.L D0,D1 \* put values in correct registers MOVE.L D7,D0 BSR send PIC command \* send to PIC MOVEM.L (A7)+,ALLREGS RTE

MOVEM.LALLREGS,-(A7)\* Preserve all registers ofMOVE.BVIA\_IFR,D0\* Read VIA interrupt flagsBTST#4,D0\* Has CB1 interrupt occurred?BNEvia\_cb1\_int\* Handle it"0 D0\* Has CA1 interrupt occurred? via\_int \* Preserve all registers on stack BNE via\_cal\_int \* Handle it \* Handle it \* If neither, return MOVEM.L (A7)+,ALLREGS RTE via\_ca1\_int MOVE.B VIA\_DRA,D0 \* Read register and clear interrupt MOVEM.L (A7)+,ALLREGS \* then return RTE via\_cb1\_int MOVE.B VIA\_DRB,D0 \* Read register and clear interrupt \* from 6522 MOVE.B VIA\_PCR,D0 \* Read current contents of PCR MOVE.B D0,D1 \* Preserve it BSET #3,D0 BSET #2,D0 \* Take CA2 low BSET BCLR #1,D0 \* do it - clears PIC interrupt MOVE.B D0,VIA\_PCR MOVEO #\$7F,D7 via\_cb1\_int\_delay DBF D7,via\_cb1\_int\_delay \* short delay loop MOVE.B D1,VIA\_PCR \* reset to original status MOVEM.L (A7)+,ALLREGS \* then return RTE memdump MOVEM.L ALLREGS,-(A7) \* Preserve registers on stack LEA \$0,A0 \* address to start at memdump\_loop1 MOVE.B (A0)+,D0 \* get byte from memory \* transmit byte MOVE.B D0,ACIA\_TR memdump\_get\_tdre1 MOVE.BACIA\_SR,D1\* get ACIA statusBTST#1,D1\* is Tx data reg emptyBEQmemdump\_get\_tdre1\* if not wait until isCMPA.L#\$4000,A0\* is end of ROM BNE memdump\_loop1 \* if not loop round \$40000,A0 \* address to start at LEA memdump\_loop2 \* get byte from memory MOVE.B (A0)+,D0 MOVE.B D0,ACIA\_TR \* transmit byte memdump\_get\_tdre2 \_get\_ture2 MOVE.B ACIA\_SR,D1 \* get ACIA status BTST#1,D1\* is Tx data reg emptyBEQmemdump\_get\_tdre2\* if not wait until is \* is end of ROM CMPA.L #\$44000,A0 \* if not loop round BNE memdump\_loop2 MOVEM.L (A7)+,ALLREGS \* Restore stacked registers \* and return RTE

#### Exception handling code

|          | ORG   | \$0     |                                        |
|----------|-------|---------|----------------------------------------|
|          | DC.L  | \$44000 | * full descending supervisor stack     |
|          | DO I  | atoxt   | * pointer                              |
|          | DC.L  | Start   | Code address to call                   |
|          | DC.L  | \$108   | * exception vector table               |
|          | DC.L  | \$10C   | * - all point to routine to set        |
|          | DC.L  | \$110   | * D0 to vector number then flash       |
|          | DC.L  | \$114   | * it on the LEDs                       |
|          | DC.L  | \$118   |                                        |
|          | DC.L  | \$11C   |                                        |
|          | DC.L  | \$120   |                                        |
|          | DC.L  | \$124   |                                        |
|          | DC.L  | \$128   |                                        |
|          | DC.L  | \$12C   |                                        |
|          | DC.L  | \$130   |                                        |
|          | DC.L  | \$134   |                                        |
|          | DC.L  | \$138   |                                        |
|          | DC.L  | \$13C   |                                        |
|          | DC.L  | \$140   |                                        |
|          | DC.L  | \$144   |                                        |
|          | DC.L  | \$148   |                                        |
|          | DC.L  | \$14C   |                                        |
|          | DC.L  | \$150   |                                        |
|          | DC.L  | \$154   |                                        |
|          | DC.L  | \$158   |                                        |
|          | DC.L  | \$15C   |                                        |
|          | DC.L  | \$160   |                                        |
|          | DC.L  | \$164   |                                        |
|          | DC.L  | \$168   |                                        |
|          | DC.L  | \$16C   |                                        |
|          | DC.L  | \$170   |                                        |
|          | DC.L  | \$174   |                                        |
|          | DC.L  | \$178   |                                        |
|          | DC.L  | \$17C   |                                        |
| trap0ve  | ctor  |         |                                        |
|          | DC.L  | trap0   | * TRAP #0 handler - OS routines        |
|          | DC.L  | trap    | * Simple trap handler – just return    |
|          | DC.L  | trap    |                                        |
| L 7 F    | DC.L  | trap    |                                        |
| trap15ve | ector | t       | י                                      |
|          | ЛС.Г  | urapi5  | " IKAP #15 Handler - hardware accesses |
|          | ORG   | \$108   | * code to set D0 to exception          |
|          | MOVEQ | #\$8,D0 | * vector number as pointed to above    |

| BRA.S  | exception |
|--------|-----------|
| MOVEQ  | #\$C,D0   |
| BRA.S  | exception |
| MOVEQ  | #\$10,D0  |
| BRA.S  | exception |
| MOVEO  | #\$14,D0  |
| BRA S  | exception |
| MOVEO  | #\$18 D0  |
| BDA C  | exception |
| MOVEO  |           |
|        | #SIC,DU   |
| BRA.5  |           |
| MOVEQ  | #\$20,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$24,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$28,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$2C,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$30,D0  |
| BRA.S  | exception |
| MOVEO  | #\$34.D0  |
| BRA S  | exception |
| MOVEO  | #\$38 D0  |
|        | avgontion |
| BRA.S  |           |
| MOVEQ  | #\$3C,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$40,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$44,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$48,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$4C,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$50,D0  |
| BRA.S  | exception |
| MOVEO  | #\$54,D0  |
| BRA S  | exception |
| MOVEO  | #\$58.D0  |
| BDA C  | exception |
| MOVEO  |           |
|        | #\$JC,DU  |
| BRA.S  | exception |
| MOVEQ  | #\$60,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$64,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$68,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$6C,D0  |
| BRA.S  | exception |
| MOVEQ  | #\$70,D0  |
| BRA.S  | exception |
| MOVEO  | #\$74,D0  |
| BRA.S  | exception |
| MOVEO  | #\$78.D0  |
| RRA C  | excention |
| MUILEO |           |
| MOVEQ  | #\$/C,DU  |
| NOL    |           |

\* Should be at \$180 by now

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

ORG \$180 exception #\$2600,SR \* Only allow NMI MOVE \* preserve exception no. MOVE.B D0,D4 MOVE.B D0,DOUT\_H \* write exception code on high LEDs MOVE.B #-1,D0 \* initial value to store on low LEDs excep\_loop \* store on low LEDs MOVE.B D0,DOUT\_L \* invert D0 NOT D0\* loop variable MOVE.W #\$FFFF,D1 \* byte excep\_time\_loop \* decrement and loop (waste time) DBF D1,excep\_time\_loop BRA.S excep\_loop excep\_serial\_send \* decrement D2 SUB #1,D2 \* is it first byte CMP #14,D2 excep\_serial\_send\_excep \* if so send exception number BEO MOVE.B (A7)+,D3\* get next byte of stack frame MOVE.B D3,ACIA\_TR \* transmit it BRA excep\_time\_loop excep\_serial\_send\_excep \* transmit exception number MOVE.B D4,ACIA\_TR BRA excep\_time\_loop ORG trap\_code trap \* Temporary code to handle TRAPs RTE \* Simply return \* Basic operating system support trap0 \* D0 contains the number of \* the routine to call CMP.B #OS\_Reset,D0 \* OS\_Reset BEQ OS\_Reset\_Code #OS\_Stop,D0 \* OS\_Stop CMP.B BEO OS\_Stop\_Code \* Unknown TRAP #0 RTE \* Handle hardware accesses trap15 \* All should be passed through here, \* so that the same code will work \* on different systems \* D0 is the number of the routine \* to be called - bits 8-15 signify \* number of device being accessed. CMP.W #Hardware RTC Read, D0 Hardware\_RTC\_Read\_Code BEO \* access real time clock #Hardware\_RTC\_Write,D0 CMP.W Hardware\_RTC\_Write\_Code \* access real time clock BEO \* Unknown TRAP #0 RTE OS\_Reset\_Code \* Go into SVC mode and do a reset RESET \* For completeness - will never get RTE \* here \* Go into SVC mode and halt OS\_Stop\_Code

STOP #\$0 \* STOP in user mode - allow all IRQs \* For completeness - will never get RTE \* here \* on entry D1 = register number Hardware\_RTC\_Read\_Code \* to read \* on exit D0 = register value MOVE.B #\$31,PIA\_CRA \* select PIA DDRA \* make Port A outputs MOVE.B #\$FF,PIA\_DDRA \* select PIA Periph Reg B MOVE.B #\$04,PIA\_CRB \* select PIA Periph Reg A (keep CA1 MOVE.B #\$35,PIA\_CRA \* interrupts enabled) MOVE.B D1,PIA\_PRA \* output address on Port A MOVE.B #\$F3,PIA\_PRB \* other bits high, enable chip, \* assert AS, read mode MOVE.B #\$F1,PIA\_PRB \* negate AS - must be 135ns between \* instructions for this to work \* without an extra delay \* select DDRA
\* make port A inputs
\* select Periph Reg A
\* other bits high, enable chip,
\* road mode assort DS MOVE.B #\$31,PIA\_CRA MOVE.B #\$00,PIA\_DDRA MOVE.B #\$35,PIA\_CRA MOVE.B #\$F5,PIA\_DDRB \* read mode, assert DS MOVE.B PIA\_PRA,D0 \* read data from Port A into DO \* other bits high, disable RTC, read MOVE.B #\$F9,PIA\_PRB \* return from exception RTE \* on entry D1 = register number Hardware\_RTC\_Write\_Code \* to write \* D2 = value to write \* select PIA DDRA MOVE.B #\$31,PIA\_CRA MOVE.B #\$FF,PIA\_DDRA MOVE.B #\$04,PIA\_CRB MOVE.B #\$35,PIA\_CRA MOVE.B D1,PIA\_PRA MOVE.B #\$F2,PIA PRB \* assert AS, write mode \* negate AS - must be 135ns between MOVE.B #\$F0,PIA\_PRB \* instructions for this to work \* without an extra delay \* select DDRA MOVE.B #\$31,PIA\_CRA MOVE.B #\$FF,PIA\_DDRA \* make port A outputs MOVE.B #\$35,PIA\_CRA MOVE.B D2,PIA\_PRA \* write data from D2 to Port A MOVE.B #\$F4,PIA\_PRB \* other bits high, enable chip, \* write mode, assert DS MOVE.B #\$F9,PIA\_PRB \* other bits high, disable RTC, read \* return from exception RTE

#### Definitions file

\* Definitions for 68k based home automation system

\* Register sets

| ALLREGS REG      | 0_0_0 | )- <u></u> 46    | * | Register set for all registers              |
|------------------|-------|------------------|---|---------------------------------------------|
| DATAREGS         | REG   | 7ת-חת            | * | Data register set                           |
| ADRREGS          | REC   | D0 D7<br>D0-D6   | * | CD Address registers                        |
| ADRICEGS         | REG   | A0 A0<br>A0-A7   | * | All Address registers                       |
| ALLADKKEGS       | REG   | AU-A7            |   | AII Address registers                       |
| * Hardware addre | esses |                  |   |                                             |
| IO_BASE          | EQU   | \$80000          | * | Allow shifting of IO space                  |
| ACIA             | EQU   | IO_BASE+\$000    |   |                                             |
| ACIA_SR          | EQU   | IO_BASE+\$000    | * | Status register - read only                 |
| ACIA_CR          | EQU   | IO_BASE+\$000    | * | Control register - write only               |
| ACIA_RR          | EQU   | IO_BASE+\$002    | * | Receive register - read only                |
| ACIA_TR          | EQU   | IO_BASE+\$002    | * | Transmit register- write only               |
| SER_BPS          | EQU   | IO_BASE+\$004    | * | Serial BPS and control lines                |
| PIA              | EOU   | IO BASE+\$200    |   |                                             |
| PIA PRA          | EOU   | IO $BASE+$200$   | * | Peripheral register A (CRA bit 2 set)       |
| PTA DDRA         | EOU   | TO BASE+ $\$200$ | * | Data direction register A (CRA bit 2 clear) |
| PTA CRA          | EOII  | TO BASE+\$202    | * | Control register A                          |
| DTA DRB          | FOII  | TO BASE+\$204    | * | Derinheral register B (CRB hit 2 set)       |
| DIA DORB         | FOII  | TO BASE+\$201    | * | Data direction register B (CRB bit 2 clear) |
| DIA CPR          | EQU   | TO_BASE+\$204    | * | Control register B                          |
| FIR_CRD          | шQО   | TO_DASE+\$200    |   |                                             |
| VIA              | EQU   | IO_BASE+\$300    |   |                                             |
| VIA_DRB          | EQU   | IO_BASE+\$300    | * | Data register B                             |
| VIA_DRA          | EQU   | IO_BASE+\$302    | * | Data register A                             |
| VIA_DDRB         | EQU   | IO_BASE+\$304    | * | Data direction register B                   |
| VIA_DDRA         | EQU   | IO_BASE+\$306    | * | Data direction register A                   |
| VIA_T1CL         | EQU   | IO_BASE+\$308    | * | T1 Low counter                              |
| VIA_T1CH         | EQU   | IO_BASE+\$30A    | * | Tl High counter                             |
| VIA T1LL         | EOU   | IO BASE+\$30C    | * | T1 Low latches                              |
| VIA T1LH         | EQU   | IO BASE+\$30E    | * | Tl High latches                             |
| VIA T2CL         | EOU   | IO BASE+\$310    | * | T2 Low counter                              |
| VIA T2CH         | EOU   | IO BASE+\$312    | * | T2 High counter                             |
| VTA SR           | EOU   | TO BASE+\$314    | * | Shift Register                              |
| VIA ACR          | EOU   | TO BASE+\$316    | * | Auxiliary Control Register                  |
| VIA PCR          | EOU   | TO BASE+ $\$318$ | * | Peripheral Control Register                 |
| VIA TER          | EOII  | TO BASE+ $\$314$ | * | Interrupt Flag Register                     |
| VIA TER          | EOII  | TO BASE+ $$31C$  | * | Interrupt Enable Register                   |
| VIA_IDRA         | FOII  | TO BASE+\$31E    | * | No Handshake DRA                            |
| VIA_NHDRA        | ΞQO   | IO_PA2F+22IF     |   | NO HAHUSHAKE DKA                            |
| DIN              | EQU   | IO_BASE+\$600    | * | Digital In                                  |
| DOUT             | EQU   | IO_BASE+\$600    | * | Digital Out                                 |
| DOUT_H           | EQU   | IO_BASE+\$600    | * | Digital Out - high byte                     |
| DOUT_L           | EQU   | IO_BASE+\$601    | * | Digital Out - low byte                      |
| RTC_SECS         | EQU   | \$00             | * | Real Time Clock internal addresses          |
| RTC_SECS_ALRM    | EQU   | \$01             |   |                                             |
| RTC_MINS         | EQU   | \$02             |   |                                             |
| RTC_MINS ALRM    | EQU   | \$03             |   |                                             |
| RTC HRS          | EQU   | \$04             |   |                                             |
| RTC HRS ALRM     | EOU   | \$05             |   |                                             |
| RTC_DAY             | EQU          | \$06                                                 |  |  |  |  |  |
|---------------------|--------------|------------------------------------------------------|--|--|--|--|--|
| RTC_DATE            | EQU          | \$07                                                 |  |  |  |  |  |
| RTC MONTH           | EOU          | \$08                                                 |  |  |  |  |  |
| RTC YEAR            | EOU          | \$09                                                 |  |  |  |  |  |
| RTC STATUS A        | EOU          | SOA                                                  |  |  |  |  |  |
| RTC STATUS B        | EOII         | \$0B                                                 |  |  |  |  |  |
| RTC STATIS C        | EQU<br>FOII  | \$0D<br>\$0C                                         |  |  |  |  |  |
|                     | EQU          | \$0C<br>¢0D                                          |  |  |  |  |  |
| RIC_SIAIUS_D        | EQU<br>DOII  |                                                      |  |  |  |  |  |
| RTC_DATE_ALRM       | EQU          | ŞUE<br>A D                                           |  |  |  |  |  |
| RTC_MONTH_ALRM      | EQU          | ŞUF                                                  |  |  |  |  |  |
| RTC_YEAR_ALRM       | EQU          | \$10                                                 |  |  |  |  |  |
|                     |              |                                                      |  |  |  |  |  |
| RTC_DEVICE_ALRM     | EQU          | \$0E                                                 |  |  |  |  |  |
| RTC_DATA_VALUE      | EQU          | \$0F                                                 |  |  |  |  |  |
| * Software inter    | rrunt i      | numberg                                              |  |  |  |  |  |
| SOLUWALE INCE       | .rupt i      | Iulibel S                                            |  |  |  |  |  |
| OC Bogot            | FOI          | ¢0 * CWI number                                      |  |  |  |  |  |
| OS_RESEL            | EQU<br>DOI   | SWI HUILDEI                                          |  |  |  |  |  |
| US_SLOP             | ЕQU          | ŞΤ                                                   |  |  |  |  |  |
|                     |              |                                                      |  |  |  |  |  |
| Serial_GetByte      | EQU          | ŞU                                                   |  |  |  |  |  |
| Serial_PutByte      | EQU          | \$1                                                  |  |  |  |  |  |
| Hardware_RTC_Wr     | lte          | EQU \$900                                            |  |  |  |  |  |
| Hardware_RTC_Rea    | ad           | EQU \$901                                            |  |  |  |  |  |
|                     |              |                                                      |  |  |  |  |  |
| * RAM allocation    | ıs           |                                                      |  |  |  |  |  |
|                     | HOIT         |                                                      |  |  |  |  |  |
| RAM_BASE            | ЕQU          | \$40000 * Allow shifting of RAM space                |  |  |  |  |  |
|                     | <b>BOT</b>   |                                                      |  |  |  |  |  |
| SERIAL_BUFLEN       | EQU          | SFF * Size of receive and transmit buffers           |  |  |  |  |  |
| SERIAL_STATUS       | EQU          | RAM_BASE+\$000 * Store serial status on IRQ          |  |  |  |  |  |
| SERIAL_RX_INPTR     | EQU          | RAM_BASE+\$002 * Pointer to store incoming data at   |  |  |  |  |  |
| SERIAL_RX_OUTPTR    |              | EQU RAM_BASE+\$004 * Pointer to read from            |  |  |  |  |  |
| SERIAL_TX_INPTR EQU |              | RAM_BASE+\$006 * Pointer to write to                 |  |  |  |  |  |
| SERIAL_TX_OUTPTH    | REQU         | RAM_BASE+\$008 * Pointer to outputting data          |  |  |  |  |  |
| SERIAL_RX_OVERFI    | MOL          | EQU RAM_BASE+\$00A * Flag to show if overflows       |  |  |  |  |  |
| SERIAL TX OVERFLOW  |              | EQU RAM BASE+\$00C * Flag to show if overflows       |  |  |  |  |  |
| SERIAL CONFIG       | EOU          | RAM BASE+\$00E                                       |  |  |  |  |  |
| SERIAL WORKSPACE    |              | EOU RAM BASE+\$980 * Workspace for string processing |  |  |  |  |  |
| SERIAL INBUF        | -<br>F∩∏     | RAM BASE+\$1000 * Serial input huffer                |  |  |  |  |  |
| GEDIAL OUTDUE       | EQU<br>FOII  | CEPTAL INDUE-CEPTAL DUELEN * Social output buffor    |  |  |  |  |  |
| CEDINI INEND        | EQU          | CEDIM OUTDUE 2                                       |  |  |  |  |  |
| SERIAL_INEND        | EQU          | SERIAL_OUIBUF-2                                      |  |  |  |  |  |
| SERIAL_OUTEND       | ЕQU          | SERIAL_INBUF+SERIAL_BUFLEN - 2                       |  |  |  |  |  |
|                     | <b>BO</b> 11 |                                                      |  |  |  |  |  |
| RTC_SC_SECS         | ЕQU          | RAM_BASE+SUIU * SOIT COPY OF Real Time Clock         |  |  |  |  |  |
| RTC_SC_SECS_ALR     | 4            | EQU RAM_BASE+\$011                                   |  |  |  |  |  |
| RTC_SC_MINS         | EQU          | RAM_BASE+\$012                                       |  |  |  |  |  |
| RTC_SC_MINS_ALRM    |              | EQU RAM_BASE+\$013                                   |  |  |  |  |  |
| RTC_SC_HRS          |              | EQU RAM_BASE+\$014                                   |  |  |  |  |  |
| RTC_SC_HRS_ALRM     | EQU          | RAM_BASE+\$015                                       |  |  |  |  |  |
| RTC_SC_DAY          |              | EQU RAM_BASE+\$016                                   |  |  |  |  |  |
| RTC_SC_DATE         | EQU          | RAM_BASE+\$017                                       |  |  |  |  |  |
| RTC SC MONTH        | EOU          | RAM BASE+\$018                                       |  |  |  |  |  |
| RTC SC YEAR         | EOU          | RAM BASE+\$019                                       |  |  |  |  |  |
|                     | ~-           |                                                      |  |  |  |  |  |
| TF_BLK              | EQU          | RAM_BASE+\$1200 * Block to hold timeframes           |  |  |  |  |  |
| TF BLK END          | EQU          | RAM BASE+\$2000 * allow plenty of space              |  |  |  |  |  |
| TF START            | EOU          | RAM BASE+\$020 * Pointer to first                    |  |  |  |  |  |
| TF END              | EOII         | RAM BASE+\$022 * Pointer to last                     |  |  |  |  |  |
|                     | -20          |                                                      |  |  |  |  |  |

Copyright Theo Markettos 1997. This may be used for educational and non-profit making purposes only. The author may be reached at theomarkettos@letterbox.com

| TF_TIME         | EQU      | \$0 | * | Offset | int | o timeframe     |
|-----------------|----------|-----|---|--------|-----|-----------------|
| TF_DEVICE       | EQU      | \$4 |   |        |     |                 |
| TF_ACTION       | EQU      | \$6 |   |        |     |                 |
| TF_LEN          | EQU      | \$A | * | Length | of  | timeframe block |
| * Miscellaneous | definiti | ons |   |        |     |                 |
| LF              | EQU      | 10  |   |        |     |                 |
| FF              | EQU      | 12  |   |        |     |                 |

13

EQU

CR

## **Bibliography and References**

Motorola, "Motorola Semiconductor Master Selection Guide", Tenth Revision, Motorola Inc., Phoenix, Arizona, 1996.

Motorola Semiconductor Products Sector, "M68000 User's Manual", Ninth Edition, Motorola Inc., Tempe, Arizona, 1994.

Motorola, "M68000 Family Programmer's Reference Manual", First Revision, Motorola Inc., Phoenix, Arizona, 1992.

Mike Tooley, "Newnes 68000 Family Pocket Book", Newnes, Oxford, 1992.

Mike Tooley, "Newnes Computer Engineer's Pocket Book", Fourth Edition, Newnes, Oxford, 1996.

Motorola Logic Integrated Circuits Division, "FAST and LS TTL Data", Fifth Edition, Motorola Inc., Phoenix, Arizona, 1992.

National Semiconductor, "National Application Specific Analog Products Databook", 1995 Edition, National Semiconductor Corporation, Santa Clara, California, 1995.

Paul Horowitz, Winfield Hill, "The Art of Electronics", Second Edition, Cambridge University Press, Cambridge, UK, 1989.

Acorn Computers Ltd, "Acorn Risc PC Welcome Guide", Issue 1, Acorn Computers Ltd, Cambridge, UK, 1994.

M. W. Brimicombe, "Electronic Systems", Thomas Nelson and Sons, Walton-on-Thames, UK, 1985.

Mark Ward, "Digital data comes down the mains", Technology, New Scientist, 18 January 1997.

"Remote control of your home energy", The Messenger, 12 February 1997.

Internet comp.home.automation newsgroup frequently asked questions list (X10 section).

Data sheets on MC68000, MC146818A, MC6821, MC6840, MC6845, MC6850, MC6854, W65C22S, MAX1691, MAX665, MAX1232, MAX238CNG, R6502, PIC16C84, OP282.

Amar Palacherla, "Application Note AN555: Software Implementation of Asynchronous Serial I/O for PIC16CXX", Arizona Microchip, Chandler, Arizona, 1995.

## Acknowledgements

Semiconductor data generously supplied free of charge by Motorola Inc., Maxim Integrated Products (UK) Ltd, The Western Design Center, Inc. (Mesa, Arizona), Analog Devices Inc., Arizona Microchip Corp., United Microsystems Corp., Rockwell Inc., and National Semiconductor Corp.

Free IC samples supplied by Maxim Integrated Products (UK) Ltd.

68000 assembler and simulator software written and made freely available by Paul McKee and Marwan Shaban, North Carolina State University.

PIC programmer hardware design and programming software by David Tait, Manchester University.

RS Components Rapid Electronics Farnell Components HB Electronics

Mr LM Holland Mr ATJ Evans