mirror of
https://github.com/dougg3/mac-rom-simm-programmer.git
synced 2024-12-22 20:29:32 +00:00
Added delay "adapter" class to keep simm_electrical_test.c completely platform-independent.
Updated the electrical class to wait after setting up pins before reading them.
This commit is contained in:
parent
fc44d70c4f
commit
65c6654660
8
delay.c
Normal file
8
delay.c
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
/*
|
||||||
|
* delay.c
|
||||||
|
*
|
||||||
|
* Created on: Dec 4, 2011
|
||||||
|
* Author: Doug
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "delay.h"
|
15
delay.h
Normal file
15
delay.h
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
/*
|
||||||
|
* delay.h
|
||||||
|
*
|
||||||
|
* Created on: Dec 4, 2011
|
||||||
|
* Author: Doug
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef DELAY_H_
|
||||||
|
#define DELAY_H_
|
||||||
|
|
||||||
|
#include <util/delay.h>
|
||||||
|
|
||||||
|
#define DelayMS(ms) _delay_ms(ms)
|
||||||
|
|
||||||
|
#endif /* DELAY_H_ */
|
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
#include "simm_electrical_test.h"
|
#include "simm_electrical_test.h"
|
||||||
#include "../ports.h"
|
#include "../ports.h"
|
||||||
|
#include "../delay.h"
|
||||||
|
|
||||||
#define SIMM_HIGHEST_ADDRESS_LINE 18
|
#define SIMM_HIGHEST_ADDRESS_LINE 18
|
||||||
#define SIMM_ADDRESS_PINS_MASK ((1UL << (SIMM_HIGHEST_ADDRESS_LINE + 1)) - 1)
|
#define SIMM_ADDRESS_PINS_MASK ((1UL << (SIMM_HIGHEST_ADDRESS_LINE + 1)) - 1)
|
||||||
@ -14,6 +15,8 @@
|
|||||||
#define SIMM_HIGHEST_DATA_LINE 31
|
#define SIMM_HIGHEST_DATA_LINE 31
|
||||||
#define SIMM_DATA_PINS_MASK (0xFFFFFFFFUL)
|
#define SIMM_DATA_PINS_MASK (0xFFFFFFFFUL)
|
||||||
|
|
||||||
|
#define DELAY_SETTLE_TIME_MS 5
|
||||||
|
|
||||||
typedef enum ElectricalTestStage
|
typedef enum ElectricalTestStage
|
||||||
{
|
{
|
||||||
TestingAddressLines,
|
TestingAddressLines,
|
||||||
@ -38,7 +41,7 @@ int SIMMElectricalTest_Run(void)
|
|||||||
Ports_AddressPullups_RMW(SIMM_ADDRESS_PINS_MASK, SIMM_ADDRESS_PINS_MASK);
|
Ports_AddressPullups_RMW(SIMM_ADDRESS_PINS_MASK, SIMM_ADDRESS_PINS_MASK);
|
||||||
Ports_DataPullups_RMW(SIMM_DATA_PINS_MASK, SIMM_DATA_PINS_MASK);
|
Ports_DataPullups_RMW(SIMM_DATA_PINS_MASK, SIMM_DATA_PINS_MASK);
|
||||||
|
|
||||||
// TODO: Wait a sec?
|
DelayMS(DELAY_SETTLE_TIME_MS);
|
||||||
|
|
||||||
if (Ports_ReadAddress() != SIMM_ADDRESS_PINS_MASK)
|
if (Ports_ReadAddress() != SIMM_ADDRESS_PINS_MASK)
|
||||||
{
|
{
|
||||||
@ -127,7 +130,8 @@ int SIMMElectricalTest_Run(void)
|
|||||||
// OK, so now we have set up all lines as needed. Exactly one pin is outputting a 0, and all other pins
|
// OK, so now we have set up all lines as needed. Exactly one pin is outputting a 0, and all other pins
|
||||||
// are inputs with pull-ups enabled. Read back all the lines, and if any pin reads back as 0,
|
// are inputs with pull-ups enabled. Read back all the lines, and if any pin reads back as 0,
|
||||||
// it means that pin is shorted to the pin we are testing (overpowering its pullup)
|
// it means that pin is shorted to the pin we are testing (overpowering its pullup)
|
||||||
// TODO: Wait a bit here for things to settle?
|
|
||||||
|
DelayMS(DELAY_SETTLE_TIME_MS);
|
||||||
|
|
||||||
uint32_t readback = Ports_ReadAddress();
|
uint32_t readback = Ports_ReadAddress();
|
||||||
if (curStage == TestingAddressLines)
|
if (curStage == TestingAddressLines)
|
||||||
|
Loading…
Reference in New Issue
Block a user