@@ -3,6 +3,7 @@
#include <linux/list.h>
#include <internal/evlist.h>
#include <internal/evsel.h>
+#include <linux/zalloc.h>
void perf_evlist__init(struct perf_evlist *evlist)
{
@@ -23,3 +24,13 @@ void perf_evlist__remove(struct perf_evlist *evlist,
list_del_init(&evsel->node);
evlist->nr_entries -= 1;
}
+
+struct perf_evlist *perf_evlist__new(void)
+{
+ struct perf_evlist *evlist = zalloc(sizeof(*evlist));
+
+ if (evlist != NULL)
+ perf_evlist__init(evlist);
+
+ return evlist;
+}
@@ -12,5 +12,6 @@ LIBPERF_API void perf_evlist__add(struct perf_evlist *evlist,
struct perf_evsel *evsel);
LIBPERF_API void perf_evlist__remove(struct perf_evlist *evlist,
struct perf_evsel *evsel);
+LIBPERF_API struct perf_evlist *perf_evlist__new(void);
#endif /* __LIBPERF_EVLIST_H */
@@ -12,6 +12,7 @@ LIBPERF_0.0.1 {
perf_thread_map__get;
perf_thread_map__put;
perf_evsel__init;
+ perf_evlist__new;
perf_evlist__init;
perf_evlist__add;
perf_evlist__remove;