mirror of
https://github.com/pevans/erc-c.git
synced 2024-11-30 08:51:53 +00:00
Add documentation; plus set sector/track pos to 0 on eject
This commit is contained in:
parent
2aeef09f97
commit
d53b6df7a4
@ -4,6 +4,11 @@
|
|||||||
|
|
||||||
#include "apple2.dd.h"
|
#include "apple2.dd.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a new disk drive. We do not create a memory segment for the
|
||||||
|
* drive right away, as the size of said data can be variable based on
|
||||||
|
* the disk format.
|
||||||
|
*/
|
||||||
apple2dd *
|
apple2dd *
|
||||||
apple2dd_create()
|
apple2dd_create()
|
||||||
{
|
{
|
||||||
@ -29,6 +34,11 @@ apple2dd_create()
|
|||||||
return drive;
|
return drive;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Insert a "disk" into the drive, such that a disk is delivered to us
|
||||||
|
* through a FILE stream. Return an error code if the disk format is
|
||||||
|
* something we cannot accept.
|
||||||
|
*/
|
||||||
int
|
int
|
||||||
apple2dd_insert(apple2dd *drive, FILE *stream)
|
apple2dd_insert(apple2dd *drive, FILE *stream)
|
||||||
{
|
{
|
||||||
@ -68,6 +78,10 @@ apple2dd_insert(apple2dd *drive, FILE *stream)
|
|||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the segment position that the drive is currently at, based
|
||||||
|
* upon track and sector position.
|
||||||
|
*/
|
||||||
int
|
int
|
||||||
apple2dd_position(apple2dd *drive)
|
apple2dd_position(apple2dd *drive)
|
||||||
{
|
{
|
||||||
@ -90,6 +104,10 @@ apple2dd_position(apple2dd *drive)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Read a single byte from the disk drive, at its current position, and
|
||||||
|
* then shift the head by 1 byte.
|
||||||
|
*/
|
||||||
vm_8bit
|
vm_8bit
|
||||||
apple2dd_read(apple2dd *drive)
|
apple2dd_read(apple2dd *drive)
|
||||||
{
|
{
|
||||||
@ -99,6 +117,10 @@ apple2dd_read(apple2dd *drive)
|
|||||||
return byte;
|
return byte;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Here we mean to "empty" the drive, essentially freeing the segment
|
||||||
|
* memory and resetting the head position.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_eject(apple2dd *drive)
|
apple2dd_eject(apple2dd *drive)
|
||||||
{
|
{
|
||||||
@ -106,8 +128,14 @@ apple2dd_eject(apple2dd *drive)
|
|||||||
vm_segment_free(drive->data);
|
vm_segment_free(drive->data);
|
||||||
drive->data = NULL;
|
drive->data = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
drive->track_pos = 0;
|
||||||
|
drive->sector_pos = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Free the memory taken up by the disk drive.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_free(apple2dd *drive)
|
apple2dd_free(apple2dd *drive)
|
||||||
{
|
{
|
||||||
@ -118,6 +146,10 @@ apple2dd_free(apple2dd *drive)
|
|||||||
free(drive);
|
free(drive);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set the disk drive mode, which is either read or write. (It can only
|
||||||
|
* be one or the other at a time.)
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_set_mode(apple2dd *drive, int mode)
|
apple2dd_set_mode(apple2dd *drive, int mode)
|
||||||
{
|
{
|
||||||
@ -128,6 +160,11 @@ apple2dd_set_mode(apple2dd *drive, int mode)
|
|||||||
drive->mode = mode;
|
drive->mode = mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Shift the head position in the drive by the given positions, which is
|
||||||
|
* in bytes. Pos may be a negative number; if so, the head essentially
|
||||||
|
* moves further away from the center of the magnetic wafer.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_shift(apple2dd *drive, int pos)
|
apple2dd_shift(apple2dd *drive, int pos)
|
||||||
{
|
{
|
||||||
@ -143,6 +180,13 @@ apple2dd_shift(apple2dd *drive, int pos)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* When you step the drive, you are essentially moving the head in
|
||||||
|
* track positions. It's not really faster for _us_, but it's faster for
|
||||||
|
* a mechanical drive than a bunch of shifts if you know the data is far
|
||||||
|
* away track-wise. This function also safeguards (as the drive did!)
|
||||||
|
* against stepping too far out or too far in.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_step(apple2dd *drive, int steps)
|
apple2dd_step(apple2dd *drive, int steps)
|
||||||
{
|
{
|
||||||
@ -155,12 +199,20 @@ apple2dd_step(apple2dd *drive, int steps)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A really simple function to turn the drive "on".
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_turn_on(apple2dd *drive, bool online)
|
apple2dd_turn_on(apple2dd *drive, bool online)
|
||||||
{
|
{
|
||||||
drive->online = online;
|
drive->online = online;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Write a byte to the disk in the drive. This is pretty similar to the
|
||||||
|
* read function in that, once we do what we need with the segment, we
|
||||||
|
* shift the drive position forward by one byte.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_write(apple2dd *drive, vm_8bit byte)
|
apple2dd_write(apple2dd *drive, vm_8bit byte)
|
||||||
{
|
{
|
||||||
@ -168,6 +220,12 @@ apple2dd_write(apple2dd *drive, vm_8bit byte)
|
|||||||
apple2dd_shift(drive, 1);
|
apple2dd_shift(drive, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set the write-protect status for the disk. Note that it was _disks_
|
||||||
|
* that were write-protected in the past, sometimes by taping over a
|
||||||
|
* chunk that was clipped out of the disk. So this function is somewhat
|
||||||
|
* similar to just taping over or removing that tape.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
apple2dd_write_protect(apple2dd *drive, bool protect)
|
apple2dd_write_protect(apple2dd *drive, bool protect)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user