|
@@ -22,7 +22,6 @@
|
|
|
#include <linux/hardirq.h>
|
|
|
#include <linux/kthread.h>
|
|
|
#include <linux/uaccess.h>
|
|
|
-#include <linux/kprobes.h>
|
|
|
#include <linux/ftrace.h>
|
|
|
#include <linux/sysctl.h>
|
|
|
#include <linux/ctype.h>
|
|
@@ -898,36 +897,6 @@ static struct dyn_ftrace *ftrace_free_records;
|
|
|
} \
|
|
|
}
|
|
|
|
|
|
-#ifdef CONFIG_KPROBES
|
|
|
-
|
|
|
-static int frozen_record_count;
|
|
|
-
|
|
|
-static inline void freeze_record(struct dyn_ftrace *rec)
|
|
|
-{
|
|
|
- if (!(rec->flags & FTRACE_FL_FROZEN)) {
|
|
|
- rec->flags |= FTRACE_FL_FROZEN;
|
|
|
- frozen_record_count++;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static inline void unfreeze_record(struct dyn_ftrace *rec)
|
|
|
-{
|
|
|
- if (rec->flags & FTRACE_FL_FROZEN) {
|
|
|
- rec->flags &= ~FTRACE_FL_FROZEN;
|
|
|
- frozen_record_count--;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static inline int record_frozen(struct dyn_ftrace *rec)
|
|
|
-{
|
|
|
- return rec->flags & FTRACE_FL_FROZEN;
|
|
|
-}
|
|
|
-#else
|
|
|
-# define freeze_record(rec) ({ 0; })
|
|
|
-# define unfreeze_record(rec) ({ 0; })
|
|
|
-# define record_frozen(rec) ({ 0; })
|
|
|
-#endif /* CONFIG_KPROBES */
|
|
|
-
|
|
|
static void ftrace_free_rec(struct dyn_ftrace *rec)
|
|
|
{
|
|
|
rec->freelist = ftrace_free_records;
|
|
@@ -1091,14 +1060,6 @@ static void ftrace_replace_code(int enable)
|
|
|
!(rec->flags & FTRACE_FL_CONVERTED))
|
|
|
continue;
|
|
|
|
|
|
- /* ignore updates to this record's mcount site */
|
|
|
- if (get_kprobe((void *)rec->ip)) {
|
|
|
- freeze_record(rec);
|
|
|
- continue;
|
|
|
- } else {
|
|
|
- unfreeze_record(rec);
|
|
|
- }
|
|
|
-
|
|
|
failed = __ftrace_replace_code(rec, enable);
|
|
|
if (failed) {
|
|
|
rec->flags |= FTRACE_FL_FAILED;
|