xref: /openbmc/linux/drivers/gpu/drm/radeon/atom-bits.h (revision 771fe6b9)
1771fe6b9SJerome Glisse /*
2771fe6b9SJerome Glisse  * Copyright 2008 Advanced Micro Devices, Inc.
3771fe6b9SJerome Glisse  *
4771fe6b9SJerome Glisse  * Permission is hereby granted, free of charge, to any person obtaining a
5771fe6b9SJerome Glisse  * copy of this software and associated documentation files (the "Software"),
6771fe6b9SJerome Glisse  * to deal in the Software without restriction, including without limitation
7771fe6b9SJerome Glisse  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8771fe6b9SJerome Glisse  * and/or sell copies of the Software, and to permit persons to whom the
9771fe6b9SJerome Glisse  * Software is furnished to do so, subject to the following conditions:
10771fe6b9SJerome Glisse  *
11771fe6b9SJerome Glisse  * The above copyright notice and this permission notice shall be included in
12771fe6b9SJerome Glisse  * all copies or substantial portions of the Software.
13771fe6b9SJerome Glisse  *
14771fe6b9SJerome Glisse  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15771fe6b9SJerome Glisse  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16771fe6b9SJerome Glisse  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17771fe6b9SJerome Glisse  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18771fe6b9SJerome Glisse  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19771fe6b9SJerome Glisse  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20771fe6b9SJerome Glisse  * OTHER DEALINGS IN THE SOFTWARE.
21771fe6b9SJerome Glisse  *
22771fe6b9SJerome Glisse  * Author: Stanislaw Skowronek
23771fe6b9SJerome Glisse  */
24771fe6b9SJerome Glisse 
25771fe6b9SJerome Glisse #ifndef ATOM_BITS_H
26771fe6b9SJerome Glisse #define ATOM_BITS_H
27771fe6b9SJerome Glisse 
get_u8(void * bios,int ptr)28771fe6b9SJerome Glisse static inline uint8_t get_u8(void *bios, int ptr)
29771fe6b9SJerome Glisse {
30771fe6b9SJerome Glisse     return ((unsigned char *)bios)[ptr];
31771fe6b9SJerome Glisse }
32771fe6b9SJerome Glisse #define U8(ptr) get_u8(ctx->ctx->bios, (ptr))
33771fe6b9SJerome Glisse #define CU8(ptr) get_u8(ctx->bios, (ptr))
get_u16(void * bios,int ptr)34771fe6b9SJerome Glisse static inline uint16_t get_u16(void *bios, int ptr)
35771fe6b9SJerome Glisse {
36771fe6b9SJerome Glisse     return get_u8(bios ,ptr)|(((uint16_t)get_u8(bios, ptr+1))<<8);
37771fe6b9SJerome Glisse }
38771fe6b9SJerome Glisse #define U16(ptr) get_u16(ctx->ctx->bios, (ptr))
39771fe6b9SJerome Glisse #define CU16(ptr) get_u16(ctx->bios, (ptr))
get_u32(void * bios,int ptr)40771fe6b9SJerome Glisse static inline uint32_t get_u32(void *bios, int ptr)
41771fe6b9SJerome Glisse {
42771fe6b9SJerome Glisse     return get_u16(bios, ptr)|(((uint32_t)get_u16(bios, ptr+2))<<16);
43771fe6b9SJerome Glisse }
44771fe6b9SJerome Glisse #define U32(ptr) get_u32(ctx->ctx->bios, (ptr))
45771fe6b9SJerome Glisse #define CU32(ptr) get_u32(ctx->bios, (ptr))
46771fe6b9SJerome Glisse #define CSTR(ptr) (((char *)(ctx->bios))+(ptr))
47771fe6b9SJerome Glisse 
48771fe6b9SJerome Glisse #endif
49