1.13. Hardware Models and Configurations

Earlier we discussed the standard option -b, which chooses among different installed compilers for completely different target machines, such as Vax vs. 68000 vs. 80386.

In addition, each of these target machine types can have its own special options, starting with -m, to choose among various hardware models or configurations—for example, 68010 vs 68020, floating coprocessor or none. A single installed version of the compiler can compile for any model or configuration, according to the options specified.

Some configurations of the compiler also support additional special options, usually for compatibility with other compilers on the same platform.

1.13.1. ERC32 Options

These -m switches are supported on the ERC32:

-mno-app-regs, -mapp-regs

Specify -mapp-regs to generate output using the global registers 2 through 4, which the SPARC SVR4 ABI reserves for applications. This is the default.

To be fully SVR4 ABI compliant at the cost of some performance loss, specify -mno-app-regs. You should compile libraries and system software with this option.

-mfpu, -mhard-float

Generate output containing floating-point instructions. This is the default.

-mno-fpu, -msoft-float

Generate output containing library calls for floating point.

Warning: The requisite floating-point emulation libraries are not provided as standard.

-msoft-float changes the calling convention in the output file; therefore, it is only useful if you compile all of a program with this option.

-mno-epilogue, -mepilogue

With -mepilogue (the default), the compiler always emits code for function exit at the end of each function. Any function exit in the middle of the function (such as a return statement in C) will generate a jump to the exit code at the end of the function.

With -mno-epilogue, the compiler tries to emit exit code inline at every function exit.

-mno-unaligned-doubles, -munaligned-doubles

Assume that doubles have 8 byte alignment. This is the default.

With -munaligned-doubles, the compiler assumes that doubles have 8 byte alignment only if they are contained in another type, or if they have an absolute address. Otherwise, it assumes they have 4 byte alignment. Specifying this option avoids some rare compatibility problems with code generated by other compilers. It is not the default because it results in a performance loss, especially for floating-point code.

-malign-loops= num

Align loops to a 2 raised to a num byte boundary. If -malign-loops is not specified, the default is 2.

-malign-jumps= num

Align instructions that are only jumped to to a 2 raised to a num byte boundary. If -malign-jumps is not specified, the default is 2.

-malign-functions= num

Align the start of functions to a 2 raised to num byte boundary. The default alignment is 4 bytes.

-mv7

Select a SPARC V7 chipset.

-mcba

Select the Temic revision CBA chipset (the default).

-mcca

Select the Temic revision CCA chipset.

-mcda

Select the Temic revision CDA chipset.

-mcpu= cpu

Generate code for cpu, where cpu is either v7, cba, cca or cda. The default is cba.