typedef guint64 uint64_t;
/* Subbuffer header */
-struct ltt_subbuffer_header_2_3 {
+struct ltt_subbuffer_header_2_4 {
uint64_t cycle_count_begin; /* Cycle count at subbuffer start */
uint64_t cycle_count_end; /* Cycle count at subbuffer end */
uint32_t magic_number; /*
char header_end[0]; /* End of header */
};
-typedef struct ltt_subbuffer_header_2_3 ltt_subbuffer_header_t;
+typedef struct ltt_subbuffer_header_2_4 ltt_subbuffer_header_t;
/*
* Return header size without padding after the structure. Don't use packed
LttTime trace_end;
};
-/* Calculate the offset needed to align the type.
+/*
+ * Calculate the offset needed to align the type.
* If alignment is 0, alignment is disactivated.
* else, the function returns the offset needed to
- * align align_drift on the alignment value (should be
- * the size of the architecture). */
+ * align align_drift on the alignment value.
+ *
+ * Do not limit alignment on architecture size anymore,
+ * because uint64_t types are aligned on 64-bit even
+ * on 32-bit archs.
+ */
static inline unsigned int ltt_align(size_t align_drift,
size_t size_of_type,
size_t alignment)
break;
case 2:
switch(header->minor_version) {
- case 3:
+ case 4:
{
- struct ltt_subbuffer_header_2_3 *vheader = header;
+ struct ltt_subbuffer_header_2_4 *vheader = header;
tf->buffer_header_size = ltt_subbuffer_header_size();
tf->tscbits = 27;
tf->eventbits = 5;
GQuark symbol = (GQuark)g_hash_table_lookup(nt->kprobe_hash,
(gconstpointer)&value);
#else
- GQuark symbol = (GQuark)g_hash_table_lookup(nt->kprobe_hash,
+ GQuark symbol = (GQuark)(unsigned long)g_hash_table_lookup(nt->kprobe_hash,
(gconstpointer)value);
#endif
if (symbol)