summaryrefslogtreecommitdiffstats
path: root/runtime/transport/ring_buffer.c
diff options
context:
space:
mode:
authorDavid Smith <dsmith@redhat.com>2009-03-31 12:02:25 -0500
committerDavid Smith <dsmith@redhat.com>2009-03-31 12:02:25 -0500
commit2e07d704dc5d7304d6a9e666553a1a8ac4382730 (patch)
treed480f2975ef3c4dca313d0e184f34d1562b5834f /runtime/transport/ring_buffer.c
parent8f47173deb9aa146b388542116d2638ed04fb03a (diff)
downloadsystemtap-steved-2e07d704dc5d7304d6a9e666553a1a8ac4382730.tar.gz
systemtap-steved-2e07d704dc5d7304d6a9e666553a1a8ac4382730.tar.xz
systemtap-steved-2e07d704dc5d7304d6a9e666553a1a8ac4382730.zip
2009-03-31 David Smith <dsmith@redhat.com>
* print_new.c (stp_print_flush): Pushed MAX_RESERVE logic down to _stp_data_write_reserve(). Now just keeps calling _stp_data_write_reserve() until it has written the entire print buffer. * transport/ring_buffer.c (_stp_data_write_reserve): Breaks large reserve requests down into smaller ones for better buffer use. Returns the number of bytes reserved. * transport/transport.h: Updated _stp_data_write_reserve() prototype.
Diffstat (limited to 'runtime/transport/ring_buffer.c')
-rw-r--r--runtime/transport/ring_buffer.c34
1 files changed, 25 insertions, 9 deletions
diff --git a/runtime/transport/ring_buffer.c b/runtime/transport/ring_buffer.c
index 1d46c378..abe9c360 100644
--- a/runtime/transport/ring_buffer.c
+++ b/runtime/transport/ring_buffer.c
@@ -317,6 +317,15 @@ static struct file_operations __stp_data_fops = {
#endif
};
+/* Here's how __STP_MAX_RESERVE_SIZE is figured. The value of
+ * BUF_PAGE_SIZE was gotten from the kernel's ring_buffer code. It
+ * is divided by 4, so we waste a maximum of 1/4 of the buffer (in
+ * the case of a small reservation). We then subtract the sizes of
+ * structures needed for every reservation. */
+#define __STP_MAX_RESERVE_SIZE ((/*BUF_PAGE_SIZE*/ 4080 / 4) \
+ - sizeof(struct _stp_entry) \
+ - sizeof(struct ring_buffer_event))
+
/*
* This function prepares the cpu buffer to write a sample.
*
@@ -329,24 +338,31 @@ static struct file_operations __stp_data_fops = {
* sample.
*
*/
-static struct _stp_entry *
-_stp_data_write_reserve(size_t size)
+static size_t
+_stp_data_write_reserve(size_t size_request, struct _stp_entry **entry)
{
struct ring_buffer_event *event;
- struct _stp_entry *entry;
+
+ if (entry == NULL)
+ return -EINVAL;
+
+ if (size_request > __STP_MAX_RESERVE_SIZE) {
+ size_request = __STP_MAX_RESERVE_SIZE;
+ }
event = ring_buffer_lock_reserve(__stp_ring_buffer,
- (sizeof(struct _stp_entry) + size),
+ (sizeof(struct _stp_entry) + size_request),
0);
if (unlikely(! event)) {
dbug_trans(1, "event = NULL (%p)?\n", event);
- return NULL;
+ entry = NULL;
+ return 0;
}
- entry = ring_buffer_event_data(event);
- entry->event = event;
- entry->len = size;
- return entry;
+ *entry = ring_buffer_event_data(event);
+ (*entry)->event = event;
+ (*entry)->len = size_request;
+ return size_request;
}
static int _stp_data_write_commit(struct _stp_entry *entry)