~helenos-nicf/helenos/nicf

« back to all changes in this revision

Viewing changes to boot/arch/ia64/src/sal.c

  • Committer: Radim Vansa
  • Date: 2011-09-20 21:55:59 UTC
  • mfrom: (697.1.517 HelenOS.mainline)
  • Revision ID: radim.vansa@matfyz.cz-20110920215559-7fjpai6wt5ieurcq
Merge with mainline

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (c) 2011 Jakub Jermar
 
3
 * All rights reserved.
 
4
 *
 
5
 * Redistribution and use in source and binary forms, with or without
 
6
 * modification, are permitted provided that the following conditions
 
7
 * are met:
 
8
 *
 
9
 * - Redistributions of source code must retain the above copyright
 
10
 *   notice, this list of conditions and the following disclaimer.
 
11
 * - Redistributions in binary form must reproduce the above copyright
 
12
 *   notice, this list of conditions and the following disclaimer in the
 
13
 *   documentation and/or other materials provided with the distribution.
 
14
 * - The name of the author may not be used to endorse or promote products
 
15
 *   derived from this software without specific prior written permission.
 
16
 *
 
17
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 
18
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 
19
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 
20
 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 
21
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 
22
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 
23
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 
24
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
25
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 
26
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
27
 */
 
28
 
 
29
#include <arch/sal.h>
 
30
#include <arch/types.h>
 
31
 
 
32
static sal_ap_wakeup_desc_t *sal_ap_wakeup;
 
33
 
 
34
extern uint64_t pal_proc;
 
35
 
 
36
uint64_t sal_proc = 0;
 
37
uint64_t sal_proc_gp = 0;
 
38
 
 
39
void sal_system_table_parse(sal_system_table_header_t *sst)
 
40
{
 
41
        uint8_t *cur = (uint8_t *) &sst[1];
 
42
        uint16_t entry;
 
43
 
 
44
        for (entry = 0; entry < sst->entry_count; entry++) {
 
45
                switch ((sal_sst_type_t) *cur) {
 
46
                case SSTT_ENTRYPOINT_DESC:
 
47
                        pal_proc = ((sal_entrypoint_desc_t *) cur)->pal_proc;
 
48
                        sal_proc = ((sal_entrypoint_desc_t *) cur)->sal_proc;
 
49
                        sal_proc_gp = ((sal_entrypoint_desc_t *) cur)->sal_proc_gp;
 
50
                        cur += sizeof(sal_entrypoint_desc_t);
 
51
                        break;
 
52
                case SSTT_MEMORY_DESC:
 
53
                        cur += sizeof(sal_memory_desc_t);
 
54
                        break;
 
55
                case SSTT_PLATFORM_FEATURES_DESC:
 
56
                        cur += sizeof(sal_platform_features_desc_t);
 
57
                        break;
 
58
                case SSTT_TR_DESC:
 
59
                        cur += sizeof(sal_tr_desc_t);
 
60
                        break;
 
61
                case SSTT_PTC_COHERENCE_DOMAIN_DESC:
 
62
                        cur += sizeof(sal_ptc_coherence_domain_desc_t);
 
63
                        break;
 
64
                case SSTT_AP_WAKEUP_DESC:
 
65
                        sal_ap_wakeup = (sal_ap_wakeup_desc_t *) cur;
 
66
                        cur += sizeof(sal_ap_wakeup_desc_t);
 
67
                        break;
 
68
                default:
 
69
                        return;
 
70
                }
 
71
        }
 
72
}
 
73
 
 
74
uint64_t sal_base_clock_frequency(void)
 
75
{
 
76
        uint64_t freq;
 
77
        
 
78
        sal_call_1_1(SAL_FREQ_BASE, 0, &freq);
 
79
        
 
80
        return freq;
 
81
}