OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [binutils-2.18.50/] [gas/] [testsuite/] [gas/] [m68hc11/] [malis.s] - Rev 825

Go to most recent revision | Compare with Previous | Blame | View Log

;;
;; This file verifies the compliance with the Motorola specification:
;; 
;; MOTOROLA STANDARDS
;; Document #1001, Version 1.0
;; SPECIFICATION FOR Motorola 8- and 16-Bit ASSEMBLY LANGUAGE INPUT STANDARD
;; 26, October 1999
;;
;; Available at:
;; 
;; http://www.mcu.motsps.com/dev_tools/hc12/eabi/m8-16alis.pdf
;;
;; Lines starting with '#' represent instructions that fail in GAS.
;;
;;
;; Section 8.2 INPUTS
	;; Validated within the whole file
 
;; Section 8.2.1 Character Set
	;; TBD
 
;; Section 8.2.2 Assembly Language Statement
	;; Validated within the whole file
 
;; Section 8.2.3 Comments
	; Motorola comment
	;; This file is full of comments
 
;; Section 8.2.5 Location Counter
	section .text
 
_start:
L0:	*			; L0 set to 0 (relative to text)
	ldaa	1,x
L1:	equ	*		; L1 set to 2 (relative to text)
 
;; Section 8.2.6 Sections
	section .data
	section .text
	section empty
	section .text
 
;; Section 8.2.7 Expressions
L2:	equ	23		; Absolute = 0x17
L3:	equ	L0-23		; Simple relocatable
 
;; Section 8.2.7.1 Primary Expression
L4:	equ	45		; Numeric  = 0x2d
L5:	equ	L0		; Symbolic
 
;; Section 8.2.7.2 Absolute Expression
L_txt:	ldaa	#44
L_txt2:
L6:	equ	-L4		; unary expr		0xffffffd3
L7:	equ	L6+1000		; binary expr		0x03bb
L8:	equ	L6-12		;			0xffffffc7
L9:	equ	L_txt2-L_txt	; reloc - reloc		2 = sizeof(ldaa #44)
 
;; Section 8.2.7.3 Simple Relocatable Expressions
L10:	equ	_start		; symbol		0 + text
L11:	equ	L10+23		; reloc+abs		0x17 + text
L12:	equ	L11-4		; reloc-abs		0x13 + text
L13:	equ	L12+L9		; reloc+abs		0x15 + text
 
;; Section 8.2.8 Symbols
	section .text
Text_Symbol:
	ldx	#Data_Symbol
 
	section .data
Data_Symbol:
 
;; Section 8.2.8.1 Labels
L_label_shall_be_significant_to_at_least_32_chars:
	dc.b	1
L_label_lower:			; Labels are case sensitive
	dc.b	2
L_Label_Lower:
	dc.b	3
 
;; Section 8.2.9 Constants
;
;	Section 8.2.9.1	Decimal Constants
	section .text
L_constant:
	ldaa	#123		; -> ldaa #0x7b
	ldaa	#-23		; -> ldaa #0xe9
 
;;	Section 8.2.9.2	Binary Constants
	ldab	#%10001010	; -> ldab #0x8A
	ldab	#%0111		; -> ldab #0x07
 
;;	Section 8.2.9.3	Octal Constants
	ldaa	#@74		; -> ldaa 0x3c
	ldaa	#@377		; -> ldaa 0xff
 
;;	Section 8.2.9.4	Hexadecimal Constants
	ldaa	#$ae		; -> ldaa 0xae
	ldaa	#$B2		; -> ldaa 0xb2
 
;;	Section 8.2.9.5	String Constants
	section	.data
#	ascii	'"Single quote string"'
	ascii	"'Double quote string'"
 
;;	Section 8.2.9.6 Floating Point Constants
;;	No specification
L_float:	float	3.241592e-2
 
;;	Section 8.2.10	Operators
	section .text
L_operator:
	ldx	#(((1<<3)&(1<<3)|2)<<4)+(4*4-1)
	ldx	#(L2>=23)&1-(L2<=23)&1+(L2==23)&1 ; -> ldx #1
	ldx	#(L2>23)&1-(L2<23)&1+(L2==23)&1   ; -> ldx #0
	ldx	#1-1+1-1+1-1
	ldab	#~L4		; -> ldab #0xd2
#	ldab	#<_start	; force to 8-bit
#	ldx	#>_start	; force to 16-bit
#	ldab	#page(_start)	; 68HC12 page number of symbol
 
;; Section 8.2.11 Instructions
;;	Defined by other tests
 
;; Section 8.2.12 Assembler Directives
;; 
;; Section 8.2.12.1 Conditional Directives
;;
# The specification says we are allowed to have spaces in expressions.
# This does not work with GAS in mri mode, the instruction 'if L2 < 24'
# is in fact treated as 'if L2'.
L_if:
	if L2<24		; true
	ldx	#1		; -> ldx #1
	else
	ldx	#2
	endif
	if L2<23||L2>23||L2==22+1 ; true
	if L2<23		; false
	ldaa	#0
	endif
	if L2>23		; false
	ldaa	#1
	endif
	if L2 == 23		; true
	ldaa	#L2+8		; -> ldaa #31
	endif
	if L2+2<23+2		; false
	if L2+4>23+4
	ldaa	#1
	elseif L2==23
	ldaa	#2
	else
	ldaa	#3
	endif
	elseif L2==23		; true
	ldaa	#4		; -> ldaa #4
	else
	ldaa	#5
	endif
	endif
	ifdef L1		; true
	ldx	#23		; -> ldx #0x17
	endif
	ifndef L_undef		; true
	ldx	#4		; -> ldx #4
	endif
 
;;	Section 8.2.12.2 Define Constant -dc
	section	.data
L_const_data:
	dc.b	(1<<3)|2	; 0x0a
	dc.w	(1<<9)+2	; 0x02 0x02
	dc.l	$12345678
	dc.b	10
	dc.l	(1<<9)*(3<<12)
#	dc.b	"Hello"
#	dc.w	"World"
#	dc.l	"!!!"
 
;;	Section 8.2.12.3 Define Constant Block -dcb
	dcb.b	3,2
	dcb.w	2,$55AA
	dcb.l	2,$12345678
	dcb.b	10,2
	dcb.w	5,$55AA
	dcb.l	2,$12345678
#	dcb.b	4, 12		; Fails in GAS due to space
 
;;	Section 8.2.12.4 Define Storage - ds
	ds.b	4
	ds.w	2
	ds.l	1
	ds	2
 
;;	Section 8.2.12.5 Equate Symbol Value - equ
L_equ1:	equ	(1<<8)+3
L_equ2:	equ	L_equ1*3
L_equ3:	equ	L_equ2-L_equ1
 
;;	Section 8.2.12.6 Include File - include
#	include 'malis-include.s'
#	include "malis-include.s"
	include malis-include.s
	include malis-include.s
 
;;	Section 8.2.12.7 Origin - org
	section .text
#	org	$100
	ldaa	#23
#	org	$200
	staa	24
#	org	$0
	rts
 
;;	Section 8.2.12.8 Define Section - section
	section .text
	ldaa	23
 
	section .data
	dc.b	23
 
;;	Section 8.2.12.9 Set Value of Symbol - set
s1:	set	3
s1:	set	4
s2:	set	s1+2
s3:	set	s2+4
 
;; Section 8.2.12.10 External Symbol Definition - xdef
	xdef	s1
	xdef	s2
	xdef	entry
 
;; Section 8.2.12.11 External Symbol Reference - xref
	section	.text
	xref	printf
	xrefb	write
entry:
	rts
 
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.