Commit 7ef37dd7 authored by Heiko Carstens's avatar Heiko Carstens Committed by Vasily Gorbik
Browse files

s390/time: remove get_tod_clock_ext()



Remove get_tod_clock_ext() and the STORE_CLOCK_EXT_SIZE define. This
enforces all users of the existing low level functions to use a union
tod_clock.

This way there is now a compile time check for the correct time and
therefore also if the size of the argument matches what will be
written to by the STORE CLOCK EXTENDED instruction.

Signed-off-by: default avatarHeiko Carstens <hca@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
parent fc4a925f
Loading
Loading
Loading
Loading
+3 −12
Original line number Diff line number Diff line
@@ -17,8 +17,6 @@
/* The value of the TOD clock for 1.1.1970. */
#define TOD_UNIX_EPOCH 0x7d91048bca000000ULL

#define STORE_CLOCK_EXT_SIZE	16	/* stcke writes 16 bytes */

extern u64 clock_comparator_max;

union tod_clock {
@@ -173,19 +171,12 @@ static inline void local_tick_enable(unsigned long long comp)

typedef unsigned long long cycles_t;

static inline void get_tod_clock_ext(char *clk)
{
	typedef struct { char _[STORE_CLOCK_EXT_SIZE]; } addrtype;

	asm volatile("stcke %0" : "=Q" (*(addrtype *) clk) : : "cc");
}

static inline unsigned long long get_tod_clock(void)
{
	char clk[STORE_CLOCK_EXT_SIZE];
	union tod_clock clk;

	get_tod_clock_ext(clk);
	return *((unsigned long long *)&clk[1]);
	store_tod_clock_ext(&clk);
	return clk.tod;
}

static inline unsigned long long get_tod_clock_fast(void)