X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=src%2Fctfser%2Fctfser.h;h=d2fb0b9126cc0fe68706065efbe981e7db9ec2b9;hb=087cd0f57f0f7d815a609a4e041d1200f380e4aa;hp=9fc3315fa861d15843b780d85214f3d2f64877bb;hpb=c4f23e30bf67d2523163614bc9461d84cbe1ae80;p=babeltrace.git diff --git a/src/ctfser/ctfser.h b/src/ctfser/ctfser.h index 9fc3315f..d2fb0b91 100644 --- a/src/ctfser/ctfser.h +++ b/src/ctfser/ctfser.h @@ -1,33 +1,17 @@ -#ifndef BABELTRACE_CTFSER_INTERNAL_H -#define BABELTRACE_CTFSER_INTERNAL_H - /* + * SPDX-License-Identifier: MIT + * * Copyright 2010-2011 EfficiOS Inc. and Linux Foundation * Copyright 2013, 2014 Jérémie Galarneau * Copyright 2017-2019 Philippe Proulx * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - * * The Common Trace Format (CTF) Specification is available at * http://www.efficios.com/ctf */ +#ifndef BABELTRACE_CTFSER_INTERNAL_H +#define BABELTRACE_CTFSER_INTERNAL_H + #include #include #include @@ -69,7 +53,7 @@ struct bt_ctfser { uint64_t stream_size_bytes; /* Memory map base address */ - struct mmap_align *base_mma; + struct mmap_align_data *base_mma; /* Stream file's path (for debugging) */ GString *path; @@ -83,7 +67,7 @@ struct bt_ctfser { * * This function opens the file `path` for writing. */ -BT_HIDDEN +BT_EXTERN_C BT_HIDDEN int bt_ctfser_init(struct bt_ctfser *ctfser, const char *path, int log_level); @@ -93,7 +77,7 @@ int bt_ctfser_init(struct bt_ctfser *ctfser, const char *path, * This function truncates the stream file so that there's no extra * padding after the last packet, and then closes the file. */ -BT_HIDDEN +BT_EXTERN_C BT_HIDDEN int bt_ctfser_fini(struct bt_ctfser *ctfser); /* @@ -101,17 +85,17 @@ int bt_ctfser_fini(struct bt_ctfser *ctfser); * * All the next writing functions are performed within this new packet. */ -BT_HIDDEN +BT_EXTERN_C BT_HIDDEN int bt_ctfser_open_packet(struct bt_ctfser *ctfser); /* * Closes the current packet, making its size `packet_size_bytes`. */ -BT_HIDDEN +BT_EXTERN_C BT_HIDDEN void bt_ctfser_close_current_packet(struct bt_ctfser *ctfser, uint64_t packet_size_bytes); -BT_HIDDEN +BT_EXTERN_C BT_HIDDEN int _bt_ctfser_increase_cur_packet_size(struct bt_ctfser *ctfser); static inline @@ -180,7 +164,7 @@ int bt_ctfser_align_offset_in_current_packet(struct bt_ctfser *ctfser, uint64_t align_size_bits; BT_ASSERT_DBG(alignment_bits > 0); - align_size_bits = ALIGN(ctfser->offset_in_cur_packet_bits, + align_size_bits = BT_ALIGN(ctfser->offset_in_cur_packet_bits, alignment_bits) - ctfser->offset_in_cur_packet_bits; if (G_UNLIKELY(!_bt_ctfser_has_space_left(ctfser, align_size_bits))) { @@ -251,7 +235,7 @@ int _bt_ctfser_write_byte_aligned_unsigned_int_no_align( break; } default: - abort(); + bt_common_abort(); } _bt_ctfser_incr_offset(ctfser, size_bits); @@ -313,7 +297,7 @@ int _bt_ctfser_write_byte_aligned_signed_int_no_align( break; } default: - abort(); + bt_common_abort(); } _bt_ctfser_incr_offset(ctfser, size_bits); @@ -420,11 +404,11 @@ int bt_ctfser_write_unsigned_int(struct bt_ctfser *ctfser, uint64_t value, } if (byte_order == LITTLE_ENDIAN) { - bt_bitfield_write_le(mmap_align_addr(ctfser->base_mma) + + bt_bitfield_write_le((uint8_t *) mmap_align_addr(ctfser->base_mma) + ctfser->mmap_base_offset, uint8_t, ctfser->offset_in_cur_packet_bits, size_bits, value); } else { - bt_bitfield_write_be(mmap_align_addr(ctfser->base_mma) + + bt_bitfield_write_be((uint8_t *) mmap_align_addr(ctfser->base_mma) + ctfser->mmap_base_offset, uint8_t, ctfser->offset_in_cur_packet_bits, size_bits, value); } @@ -465,11 +449,11 @@ int bt_ctfser_write_signed_int(struct bt_ctfser *ctfser, int64_t value, } if (byte_order == LITTLE_ENDIAN) { - bt_bitfield_write_le(mmap_align_addr(ctfser->base_mma) + + bt_bitfield_write_le((uint8_t *) mmap_align_addr(ctfser->base_mma) + ctfser->mmap_base_offset, uint8_t, ctfser->offset_in_cur_packet_bits, size_bits, value); } else { - bt_bitfield_write_be(mmap_align_addr(ctfser->base_mma) + + bt_bitfield_write_be((uint8_t *) mmap_align_addr(ctfser->base_mma) + ctfser->mmap_base_offset, uint8_t, ctfser->offset_in_cur_packet_bits, size_bits, value); }