162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#ifndef _ASM_MIPS_BOARDS_LAUNCH_H
762306a36Sopenharmony_ci#define _ASM_MIPS_BOARDS_LAUNCH_H
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#ifndef _ASSEMBLER_
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_cistruct cpulaunch {
1262306a36Sopenharmony_ci    unsigned long	pc;
1362306a36Sopenharmony_ci    unsigned long	gp;
1462306a36Sopenharmony_ci    unsigned long	sp;
1562306a36Sopenharmony_ci    unsigned long	a0;
1662306a36Sopenharmony_ci    unsigned long	_pad[3]; /* pad to cache line size to avoid thrashing */
1762306a36Sopenharmony_ci    unsigned long	flags;
1862306a36Sopenharmony_ci};
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci#else
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci#define LOG2CPULAUNCH	5
2362306a36Sopenharmony_ci#define LAUNCH_PC	0
2462306a36Sopenharmony_ci#define LAUNCH_GP	4
2562306a36Sopenharmony_ci#define LAUNCH_SP	8
2662306a36Sopenharmony_ci#define LAUNCH_A0	12
2762306a36Sopenharmony_ci#define LAUNCH_FLAGS	28
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci#endif
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci#define LAUNCH_FREADY	1
3262306a36Sopenharmony_ci#define LAUNCH_FGO	2
3362306a36Sopenharmony_ci#define LAUNCH_FGONE	4
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci#define CPULAUNCH	0x00000f00
3662306a36Sopenharmony_ci#define NCPULAUNCH	8
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci/* Polling period in count cycles for secondary CPU's */
3962306a36Sopenharmony_ci#define LAUNCHPERIOD	10000
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci#endif /* _ASM_MIPS_BOARDS_LAUNCH_H */
42