X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=libust%2Frelay.h;h=ba7c1d63aa2d10c35349bf2d86b70e9000228e04;hb=c8b4275ed4a63a4bc374a9f3dc864725882c750e;hp=630c4eacc5ebd3e43995d93eb06920b7719a98dc;hpb=9160b4e4541d3a6010e4e671ee5deb3ea89f4211;p=lttng-ust.git diff --git a/libust/relay.h b/libust/relay.h index 630c4eac..ba7c1d63 100644 --- a/libust/relay.h +++ b/libust/relay.h @@ -215,16 +215,24 @@ static inline struct buf_page *ltt_relay_cache_page(struct rchan_buf *buf, //ust// #ifdef CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS static inline void ltt_relay_do_copy(void *dest, const void *src, size_t len) { + union { + const void *src; + const u8 *src8; + const u16 *src16; + const u32 *src32; + const u64 *src64; + } u = { .src = src }; + switch (len) { case 0: break; - case 1: *(u8 *)dest = *(const u8 *)src; + case 1: *(u8 *)dest = *u.src8; break; - case 2: *(u16 *)dest = *(const u16 *)src; + case 2: *(u16 *)dest = *u.src16; break; - case 4: *(u32 *)dest = *(const u32 *)src; + case 4: *(u32 *)dest = *u.src32; break; //ust// #if (BITS_PER_LONG == 64) - case 8: *(u64 *)dest = *(const u64 *)src; + case 8: *(u64 *)dest = *u.src64; break; //ust// #endif default: