summaryrefslogtreecommitdiffstats
path: root/arch/xtensa/include/asm/ftrace.h
blob: 6c6d9a9f185f8803ca534543a526422b03234ebc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
 * arch/xtensa/include/asm/ftrace.h
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 *
 * Copyright (C) 2013 Tensilica Inc.
 */
#ifndef _XTENSA_FTRACE_H
#define _XTENSA_FTRACE_H

#include <asm/processor.h>

#ifndef __ASSEMBLY__
#define ftrace_return_address0 ({ unsigned long a0, a1; \
		__asm__ __volatile__ ( \
			"mov %0, a0\n" \
			"mov %1, a1\n" \
			: "=r"(a0), "=r"(a1)); \
		MAKE_PC_FROM_RA(a0, a1); })

#ifdef CONFIG_FRAME_POINTER
extern unsigned long return_address(unsigned level);
#define ftrace_return_address(n) return_address(n)
#endif
#endif /* __ASSEMBLY__ */

#ifdef CONFIG_FUNCTION_TRACER

#define MCOUNT_ADDR ((unsigned long)(_mcount))
#define MCOUNT_INSN_SIZE 3

#ifndef __ASSEMBLY__
extern void _mcount(void);
#define mcount _mcount
#endif /* __ASSEMBLY__ */
#endif /* CONFIG_FUNCTION_TRACER */

#endif /* _XTENSA_FTRACE_H */
9;]) exe "normal i\<C-G>u" exe "normal Gkylpa\<C-G>u" set ul=100 exe "normal Gylpa\<C-G>u" set ul=100 normal gg vsplit normal g; call assert_equal([3, 2], [line('.'), col('.')]) normal g; call assert_equal([2, 2], [line('.'), col('.')]) call assert_fails('normal g;', 'E662:') new call assert_fails('normal g;', 'E664:') %bwipe! let &ul = save_ul endfunc " Moving a split should not change its changelist index. func Test_changelist_index_move_split() exe "norm! iabc\<C-G>u\ndef\<C-G>u\nghi" vsplit normal 99g; call assert_equal(0, getchangelist('%')[1]) wincmd L call assert_equal(0, getchangelist('%')[1]) endfunc " Tests for the getchangelist() function func Test_changelist_index() edit Xgclfile1.txt exe "normal iabc\<C-G>u\ndef\<C-G>u\nghi" call assert_equal(3, getchangelist('%')[1]) " Move one step back in the changelist. normal 2g; hide edit Xgclfile2.txt exe "normal iabcd\<C-G>u\ndefg\<C-G>u\nghij" call assert_equal(3, getchangelist('%')[1]) " Move to the beginning of the changelist. normal 99g; " Check the changelist indices. call assert_equal(0, getchangelist('%')[1]) call assert_equal(1, getchangelist('#')[1]) bwipe! call delete('Xgclfile1.txt') call delete('Xgclfile2.txt') endfunc func Test_getchangelist() bwipe! enew call assert_equal([], 10->getchangelist()) call assert_equal([[], 0], getchangelist()) call writefile(['line1', 'line2', 'line3'], 'Xclistfile1.txt', 'D') call writefile(['line1', 'line2', 'line3'], 'Xclistfile2.txt', 'D') edit Xclistfile1.txt let buf_1 = bufnr() exe "normal 1Goline\<C-G>u1.1" exe "normal 3Goline\<C-G>u2.1" exe "normal 5Goline\<C-G>u3.1" normal g; call assert_equal([[ \ {'lnum' : 2, 'col' : 4, 'coladd' : 0}, \ {'lnum' : 4, 'col' : 4, 'coladd' : 0}, \ {'lnum' : 6, 'col' : 4, 'coladd' : 0}], 2], \ getchangelist('%')) hide edit Xclistfile2.txt let buf_2 = bufnr() exe "normal 1GOline\<C-G>u1.0" exe "normal 2Goline\<C-G>u2.0" call assert_equal([[ \ {'lnum' : 1, 'col' : 6, 'coladd' : 0}, \ {'lnum' : 3, 'col' : 6, 'coladd' : 0}], 2], \ getchangelist('%')) hide enew call assert_equal([[ \ {'lnum' : 2, 'col' : 4, 'coladd' : 0}, \ {'lnum' : 4, 'col' : 4, 'coladd' : 0}, \ {'lnum' : 6, 'col' : 4, 'coladd' : 0}], 2], \ getchangelist(buf_1)) call assert_equal([[ \ {'lnum' : 1, 'col' : 6, 'coladd' : 0}, \ {'lnum' : 3, 'col' : 6, 'coladd' : 0}], 2], \ getchangelist(buf_2)) bwipe! endfunc " vim: shiftwidth=2 sts=2 expandtab