Annotation of hatari/src/reset.c, revision 1.1.1.19

1.1       root        1: /*
                      2:   Hatari
                      3: 
1.1.1.18  root        4:   This file is distributed under the GNU General Public License, version 2
                      5:   or at your option any later version. Read the file gpl.txt for details.
1.1.1.4   root        6: 
                      7:   Reset emulation state.
1.1       root        8: */
1.1.1.13  root        9: const char Reset_fileid[] = "Hatari reset.c : " __DATE__ " " __TIME__;
1.1       root       10: 
                     11: #include "main.h"
1.1.1.10  root       12: #include "configuration.h"
1.1       root       13: #include "cart.h"
1.1.1.8   root       14: #include "dmaSnd.h"
1.1.1.14  root       15: #include "crossbar.h"
1.1       root       16: #include "fdc.h"
                     17: #include "floppy.h"
                     18: #include "gemdos.h"
1.1.1.19! root       19: #include "hdc.h"
1.1.1.18  root       20: #include "acia.h"
1.1       root       21: #include "ikbd.h"
1.1.1.14  root       22: #include "cycInt.h"
1.1       root       23: #include "m68000.h"
                     24: #include "mfp.h"
1.1.1.12  root       25: #include "midi.h"
1.1       root       26: #include "psg.h"
                     27: #include "reset.h"
                     28: #include "screen.h"
                     29: #include "sound.h"
                     30: #include "stMemory.h"
                     31: #include "tos.h"
1.1.1.10  root       32: #include "vdi.h"
1.1.1.18  root       33: #include "nvram.h"
1.1       root       34: #include "video.h"
1.1.1.10  root       35: #include "falcon/videl.h"
1.1.1.17  root       36: #include "falcon/dsp.h"
1.1.1.15  root       37: #include "debugcpu.h"
                     38: #include "debugdsp.h"
1.1.1.2   root       39: 
                     40: /*-----------------------------------------------------------------------*/
1.1.1.10  root       41: /**
                     42:  * Reset ST emulator states, chips, interrupts and registers.
                     43:  * Return zero or negative TOS image load error code.
                     44:  */
1.1.1.11  root       45: static int Reset_ST(bool bCold)
1.1       root       46: {
1.1.1.10  root       47:        if (bCold)
                     48:        {
                     49:                int ret;
                     50: 
                     51:                Floppy_GetBootDrive();      /* Find which device to boot from (A: or C:) */
                     52: 
                     53:                ret = TOS_LoadImage();      /* Load TOS, writes into cartridge memory */
                     54:                if (ret)
                     55:                        return ret;               /* If we can not load a TOS image, return now! */
                     56: 
                     57:                Cart_ResetImage();          /* Load cartridge program into ROM memory. */
                     58:        }
1.1.1.14  root       59:        CycInt_Reset();               /* Reset interrupts */
1.1.1.10  root       60:        MFP_Reset();                  /* Setup MFP chip */
                     61:        Video_Reset();                /* Reset video */
1.1.1.16  root       62:        VDI_Reset();                  /* Reset internal VDI variables */
1.1.1.18  root       63:        NvRam_Reset();                /* reset NvRAM (video) settings */
1.1.1.10  root       64: 
                     65:        GemDOS_Reset();               /* Reset GEMDOS emulation */
                     66:        if (bCold)
                     67:        {
1.1.1.19! root       68:                FDC_Reset( bCold );     /* Reset FDC */
1.1.1.10  root       69:        }
1.1.1.16  root       70:        Floppy_Reset();                 /* Reset Floppy */
1.1.1.10  root       71: 
1.1.1.19! root       72:        if (ConfigureParams.System.nMachineType == MACHINE_FALCON
        !            73:            || ConfigureParams.System.nMachineType == MACHINE_TT)
        !            74:        {
        !            75:                Ncr5380_Reset();
        !            76:        }
        !            77: 
        !            78:        if (ConfigureParams.System.nMachineType == MACHINE_FALCON)
        !            79:        {
1.1.1.17  root       80:                DSP_Reset();                  /* Reset the DSP */
1.1.1.14  root       81:                Crossbar_Reset(bCold);        /* Reset Crossbar sound */
1.1.1.17  root       82:        }
1.1.1.14  root       83:        else
                     84:                DmaSnd_Reset(bCold);          /* Reset DMA sound */
                     85: 
1.1.1.10  root       86:        PSG_Reset();                  /* Reset PSG */
                     87:        Sound_Reset();                /* Reset Sound */
1.1.1.18  root       88:        ACIA_Reset( ACIA_Array );     /* ACIA */
                     89:        IKBD_Reset(bCold);            /* Keyboard (after ACIA) */
1.1.1.10  root       90:        if (ConfigureParams.System.nMachineType == MACHINE_FALCON && !bUseVDIRes)
                     91:                VIDEL_reset();
                     92:        else
                     93:                Screen_Reset();               /* Reset screen */
                     94:        M68000_Reset(bCold);          /* Reset CPU */
                     95: 
1.1.1.15  root       96:        DebugCpu_SetDebugging();      /* Re-set debugging flag if needed */
                     97:        DebugDsp_SetDebugging();
                     98: 
1.1.1.12  root       99:        Midi_Reset();
                    100: 
1.1.1.13  root      101:        /* Start HBL, Timer B and VBL interrupts with a 0 cycle delay */
                    102:        Video_StartInterrupts( 0 );
1.1.1.7   root      103: 
1.1.1.10  root      104:        return 0;
1.1       root      105: }
                    106: 
1.1.1.2   root      107: 
                    108: /*-----------------------------------------------------------------------*/
1.1.1.10  root      109: /**
                    110:  * Cold reset ST (reset memory, all registers and reboot)
                    111:  */
                    112: int Reset_Cold(void)
1.1       root      113: {
1.1.1.10  root      114:        Main_WarpMouse(sdlscrn->w/2, sdlscrn->h/2);  /* Set mouse pointer to the middle of the screen */
                    115: 
1.1.1.13  root      116:        return Reset_ST(true);
1.1       root      117: }
                    118: 
1.1.1.2   root      119: 
                    120: /*-----------------------------------------------------------------------*/
1.1.1.10  root      121: /**
                    122:  * Warm reset ST (reset registers, leave in same state and reboot)
                    123:  */
                    124: int Reset_Warm(void)
1.1       root      125: {
1.1.1.13  root      126:        return Reset_ST(false);
1.1       root      127: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.