Trivial update of Config-lab.lb so that it works again.
[coreboot.git] / payloads / libpayload / include / arch / msr.h
1 /*
2  * This file is part of the libpayload project.
3  *
4  * Copyright (C) 2008 Advanced Micro Devices, Inc.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. 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  * 3. 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 AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  */
29
30 #ifndef _ARCH_MSR_H
31 #define _ARCH_MSR_H
32
33 static inline unsigned long long _rdmsr(unsigned int msr)
34 {
35         unsigned long long val;
36         asm volatile("rdmsr" : "=A" (val) : "c" (msr));
37         return val;
38 }
39
40 static inline void _wrmsr(unsigned int msr, unsigned long long val)
41 {
42         asm volatile("wrmsr" : : "c" (msr), "A"(val));
43 }
44
45 #define rdmsr(_m, _l, _h) \
46         do { \
47                 unsigned long long _v = _rdmsr((_m)); \
48                 (_l) = (unsigned int) _v; \
49                 (_h) = (unsigned int) ((_v >> 32) & 0xFFFFFFFF); \
50         } while(0)
51
52 static inline void wrmsr(unsigned int msr, unsigned int lo, unsigned int hi)
53 {
54         unsigned long long val = (((unsigned long long) hi) << 32) | lo;
55         _wrmsr(msr, val);
56 }
57
58 #endif