summaryrefslogtreecommitdiff
path: root/cpu/amd/geode_lx/gplvsa_ii/legacy/legacy.c
blob: cf3f8699a157ddd78c95ffe035d07235d09edab0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
* Copyright (c) 2006-2008 Advanced Micro Devices,Inc. ("AMD").
*
* This library is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of the
* License, or (at your option) any later version.
*
* This code is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.

* You should have received a copy of the GNU Lesser General
* Public License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307 USA 
*/

//*  Function:                                                          *
//*     This file implements miscellaneous VSA functionality:           *
//*                                                                     *
//*     All chipsets:                                                   *
//*       1) SYSINFO virtual registers                                  *
//*                                                                     *
//*     CS5536 :                                                        *
//*       1) Emulation of CS5530 PCI interrupt steering registers.      *
//*       2) Flash-IDE switching                                        *
//*       3) Power management                                           * 


#include "vsa2.h"
#include "chipset.h"
#include "protos.h"

// Function prototypes
extern void Legacy_Early_Init(void);
extern void Legacy_Late_Init(void);
extern void Handle_Events(ULONG *);


// Local variables
Hardware SystemInfo;
ULONG ChipsetBase;
ULONG Param[MAX_MSG_PARAM];



//***********************************************************************
// Message handler for the Legacy VSM
//***********************************************************************
void VSM_msg_loop()
{ MSG Msg;

  // Get information about the system I'm executing on.
  SYS_GET_SYSTEM_INFO(&SystemInfo);
  ChipsetBase = SystemInfo.Chipset_Base;

  //
  // Message Handling Loop
  //
  do {

    // Get the next message
    Msg = SYS_GET_NEXT_MSG(&Param);

    switch (Msg) {

      case MSG_INITIALIZE:
        switch (Param[0]) {
          case EARLY_INIT:
            Legacy_Early_Init();
            break;

          case END_OF_POST_INIT:
            Legacy_Late_Init();
            break;
        }
        break;

      case MSG_EVENT:
        Handle_Events(Param);
        break;

      case MSG_SET_POWER_MODE:
      case MSG_SET_POWER_STATE:
      case MSG_SAVE_STATE:
      case MSG_RESTORE_STATE:
        break;
    } // end switch(Msg)
  } while (1);
}