2 * Special handling for the MS-DOS derivative: syslinux_ldlinux
6 #define _XOPEN_SOURCE 500 /* Required on glibc 2.x */
16 static inline void *set_fs_sl(const void *p
)
20 seg
= ds() + ((size_t) p
>> 4);
22 return (void *)((size_t) p
& 0xf);
26 uint8_t get_8_sl(const uint8_t * p
)
31 asm volatile("movb %%fs:%1,%0":"=q" (v
):"m"(*p
));
36 uint16_t get_16_sl(const uint16_t * p
)
41 asm volatile("movw %%fs:%1,%0":"=r" (v
):"m"(*p
));
45 uint32_t get_32_sl(const uint32_t * p
)
50 asm volatile("movl %%fs:%1,%0":"=r" (v
):"m"(*p
));
55 uint64_t get_64_sl(const uint64_t * p
)
58 const uint32_t *pp
= (const uint32_t *)set_fs_sl(p
);
60 asm volatile("movl %%fs:%1,%0" : "=r" (v0
) : "m" (pp
[0]));
61 asm volatile("movl %%fs:%1,%0" : "=r" (v1
) : "m" (pp
[1]));
62 return v0
+ ((uint64_t)v1
<< 32);
67 void set_8_sl(uint8_t * p
, uint8_t v
)
70 asm volatile("movb %1,%%fs:%0":"=m" (*p
):"qi"(v
));
74 void set_16_sl(uint16_t * p
, uint16_t v
)
77 asm volatile("movw %1,%%fs:%0":"=m" (*p
):"ri"(v
));
80 void set_32_sl(uint32_t * p
, uint32_t v
)
83 asm volatile("movl %1,%%fs:%0":"=m" (*p
):"ri"(v
));
86 void set_64_sl(uint64_t * p
, uint64_t v
)
88 uint32_t *pp
= (uint32_t *)set_fs_sl(p
);
89 asm volatile("movl %1,%%fs:%0" : "=m" (pp
[0]) : "ri"((uint32_t)v
));
90 asm volatile("movl %1,%%fs:%0" : "=m" (pp
[1]) : "ri"((uint32_t)(v
>> 32)));
93 void memcpy_to_sl(void *dst
, const void *src
, size_t len
)
98 seg
= ds() + ((size_t)dst
>> 4);
99 off
= (size_t)dst
& 15;
101 asm volatile("pushw %%es ; "
105 : "+D" (off
), "+S" (src
), "+c" (len
)
110 void memcpy_from_sl(void *dst
, const void *src
, size_t len
)
115 seg
= ds() + ((size_t)src
>> 4);
116 off
= (size_t)src
& 15;
118 asm volatile("pushw %%ds ; "
122 : "+D" (dst
), "+S" (off
), "+c" (len
)