static void debug_info_get(debug_info_t *);
 static void debug_info_put(debug_info_t *);
 static int debug_prolog_level_fn(debug_info_t *id,
-                                struct debug_view *view, char *out_buf);
+                                struct debug_view *view, char *out_buf,
+                                size_t out_buf_size);
 static int debug_input_level_fn(debug_info_t *id, struct debug_view *view,
                                struct file *file, const char __user *user_buf,
                                size_t user_buf_size, loff_t *offset);
 static int debug_prolog_pages_fn(debug_info_t *id,
-                                struct debug_view *view, char *out_buf);
+                                struct debug_view *view, char *out_buf,
+                                size_t out_buf_size);
 static int debug_input_pages_fn(debug_info_t *id, struct debug_view *view,
                                struct file *file, const char __user *user_buf,
                                size_t user_buf_size, loff_t *offset);
                                struct file *file, const char __user *user_buf,
                                size_t user_buf_size, loff_t *offset);
 static int debug_hex_ascii_format_fn(debug_info_t *id, struct debug_view *view,
-                                    char *out_buf, const char *in_buf);
+                                    char *out_buf, size_t out_buf_size,
+                                    const char *in_buf);
 static int debug_sprintf_format_fn(debug_info_t *id, struct debug_view *view,
-                                  char *out_buf, const char *inbuf);
+                                  char *out_buf, size_t out_buf_size,
+                                  const char *inbuf);
 static void debug_areas_swap(debug_info_t *a, debug_info_t *b);
 static void debug_events_append(debug_info_t *dest, debug_info_t *src);
 
 
        if (p_info->act_entry == DEBUG_PROLOG_ENTRY) {
                /* print prolog */
-               if (view->prolog_proc)
-                       len += view->prolog_proc(id_snap, view, p_info->temp_buf);
+               if (view->prolog_proc) {
+                       len += view->prolog_proc(id_snap, view, p_info->temp_buf,
+                                                sizeof(p_info->temp_buf));
+               }
                goto out;
        }
        if (!id_snap->areas) /* this is true, if we have a prolog only view */
 
        if (act_entry->clock == 0LL)
                goto out; /* empty entry */
-       if (view->header_proc)
+       if (view->header_proc) {
                len += view->header_proc(id_snap, view, p_info->act_area,
-                                        act_entry, p_info->temp_buf + len);
-       if (view->format_proc)
+                                        act_entry, p_info->temp_buf + len,
+                                        sizeof(p_info->temp_buf) - len);
+       }
+       if (view->format_proc) {
                len += view->format_proc(id_snap, view, p_info->temp_buf + len,
+                                        sizeof(p_info->temp_buf) - len,
                                         DEBUG_DATA(act_entry));
+       }
 out:
        return len;
 }
  */
 
 static int debug_prolog_pages_fn(debug_info_t *id, struct debug_view *view,
-                                char *out_buf)
+                                char *out_buf, size_t out_buf_size)
 {
-       return sprintf(out_buf, "%i\n", id->pages_per_area);
+       return scnprintf(out_buf, out_buf_size, "%i\n", id->pages_per_area);
 }
 
 /*
  * prints out actual debug level
  */
 static int debug_prolog_level_fn(debug_info_t *id, struct debug_view *view,
-                                char *out_buf)
+                                char *out_buf, size_t out_buf_size)
 {
        int rc = 0;
 
        if (id->level == DEBUG_OFF_LEVEL)
-               rc = sprintf(out_buf, "-\n");
+               rc = scnprintf(out_buf, out_buf_size, "-\n");
        else
-               rc = sprintf(out_buf, "%i\n", id->level);
+               rc = scnprintf(out_buf, out_buf_size, "%i\n", id->level);
        return rc;
 }
 
  * prints debug data in hex/ascii format
  */
 static int debug_hex_ascii_format_fn(debug_info_t *id, struct debug_view *view,
-                                    char *out_buf, const char *in_buf)
+                                    char *out_buf, size_t out_buf_size, const char *in_buf)
 {
        int i, rc = 0;
 
-       for (i = 0; i < id->buf_size; i++)
-               rc += sprintf(out_buf + rc, "%02x ", ((unsigned char *) in_buf)[i]);
-       rc += sprintf(out_buf + rc, "| ");
+       for (i = 0; i < id->buf_size; i++) {
+               rc += scnprintf(out_buf + rc, out_buf_size - rc,
+                               "%02x ", ((unsigned char *)in_buf)[i]);
+       }
+       rc += scnprintf(out_buf + rc, out_buf_size - rc, "| ");
        for (i = 0; i < id->buf_size; i++) {
                unsigned char c = in_buf[i];
 
                if (isascii(c) && isprint(c))
-                       rc += sprintf(out_buf + rc, "%c", c);
+                       rc += scnprintf(out_buf + rc, out_buf_size - rc, "%c", c);
                else
-                       rc += sprintf(out_buf + rc, ".");
+                       rc += scnprintf(out_buf + rc, out_buf_size - rc, ".");
        }
-       rc += sprintf(out_buf + rc, "\n");
+       rc += scnprintf(out_buf + rc, out_buf_size - rc, "\n");
        return rc;
 }
 
  * prints header for debug entry
  */
 int debug_dflt_header_fn(debug_info_t *id, struct debug_view *view,
-                        int area, debug_entry_t *entry, char *out_buf)
+                        int area, debug_entry_t *entry, char *out_buf,
+                        size_t out_buf_size)
 {
        unsigned long sec, usec;
        unsigned long caller;
        else
                except_str = "-";
        caller = (unsigned long) entry->caller;
-       rc += sprintf(out_buf, "%02i %011ld:%06lu %1u %1s %04u %px  ",
-                     area, sec, usec, level, except_str,
-                     entry->cpu, (void *)caller);
+       rc += scnprintf(out_buf, out_buf_size, "%02i %011ld:%06lu %1u %1s %04u %px  ",
+                       area, sec, usec, level, except_str,
+                       entry->cpu, (void *)caller);
        return rc;
 }
 EXPORT_SYMBOL(debug_dflt_header_fn);
 #define DEBUG_SPRINTF_MAX_ARGS 10
 
 static int debug_sprintf_format_fn(debug_info_t *id, struct debug_view *view,
-                                  char *out_buf, const char *inbuf)
+                                  char *out_buf, size_t out_buf_size, const char *inbuf)
 {
        debug_sprintf_entry_t *curr_event = (debug_sprintf_entry_t *)inbuf;
        int num_longs, num_used_args = 0, i, rc = 0;
                goto out; /* bufsize of entry too small */
        if (num_longs == 1) {
                /* no args, we use only the string */
-               strcpy(out_buf, curr_event->string);
-               rc = strlen(curr_event->string);
+               rc = strscpy(out_buf, curr_event->string, out_buf_size);
+               if (rc == -E2BIG)
+                       rc = out_buf_size;
                goto out;
        }
 
        for (i = 0; i < num_used_args; i++)
                index[i] = i;
 
-       rc = sprintf(out_buf, curr_event->string, curr_event->args[index[0]],
-                    curr_event->args[index[1]], curr_event->args[index[2]],
-                    curr_event->args[index[3]], curr_event->args[index[4]],
-                    curr_event->args[index[5]], curr_event->args[index[6]],
-                    curr_event->args[index[7]], curr_event->args[index[8]],
-                    curr_event->args[index[9]]);
+       rc = scnprintf(out_buf, out_buf_size,
+                      curr_event->string, curr_event->args[index[0]],
+                      curr_event->args[index[1]], curr_event->args[index[2]],
+                      curr_event->args[index[3]], curr_event->args[index[4]],
+                      curr_event->args[index[5]], curr_event->args[index[6]],
+                      curr_event->args[index[7]], curr_event->args[index[8]],
+                      curr_event->args[index[9]]);
 out:
        return rc;
 }