Xiang, Haihao 95d0ce48f6 fix jump count for Sandybridge.
It is same as Ironlake.

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
2013-03-04 15:54:27 +00:00

169 lines
4.0 KiB
C

/* -*- c-basic-offset: 8 -*- */
/*
* Copyright © 2006 Intel Corporation
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice (including the next
* paragraph) shall be included in all copies or substantial portions of the
* Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
* Authors:
* Eric Anholt <eric@anholt.net>
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <getopt.h>
#include <unistd.h>
#include "gen4asm.h"
extern FILE *yyin;
extern int errors;
long int gen_level = 4;
char *input_filename = "<stdin>";
struct brw_program compiled_program;
static const struct option longopts[] = {
{ NULL, 0, NULL, 0 }
};
static void usage(void)
{
fprintf(stderr, "usage: intel-gen4asm [-o outputfile] [-g <4|5|6>] inputfile\n");
}
int main(int argc, char **argv)
{
char *output_file = NULL;
FILE *output = stdout;
struct brw_program_instruction *entry, *entry1;
int err, inst_offset;
char o;
while ((o = getopt_long(argc, argv, "o:g:", longopts, NULL)) != -1) {
switch (o) {
case 'o':
if (strcmp(optarg, "-") != 0)
output_file = optarg;
break;
case 'g':
gen_level = strtol(optarg, NULL, 0);
if (gen_level < 4 || gen_level > 6) {
usage();
exit(1);
}
break;
default:
usage();
exit(1);
}
}
argc -= optind;
argv += optind;
if (argc != 1) {
usage();
exit(1);
}
if (strcmp(argv[0], "-") != 0) {
input_filename = argv[0];
yyin = fopen(input_filename, "r");
if (yyin == NULL) {
perror("Couldn't open input file");
exit(1);
}
}
err = yyparse();
if (err || errors)
exit (1);
if (output_file) {
output = fopen(output_file, "w");
if (output == NULL) {
perror("Couldn't open output file");
exit(1);
}
}
inst_offset = 0 ;
for (entry = compiled_program.first;
entry != NULL; entry = entry->next) {
entry->inst_offset = inst_offset;
if (!entry->islabel)
inst_offset++;
}
for (entry = compiled_program.first;
entry != NULL; entry = entry->next) {
if (!entry->islabel) {
if (entry->instruction.reloc_target) {
for (entry1 = entry;
entry1 != NULL; entry1 = entry1->next) {
if (entry1->islabel &&
strcmp(entry1->string,
entry->instruction.reloc_target) == 0) {
int offset =
entry1->inst_offset - entry->inst_offset;
if (gen_level >= 5)
entry->instruction.bits3.ud = 2 * (offset - 1);
else
entry->instruction.bits3.ud = offset - 1;
break;
}
}
if (entry1 == NULL)
fprintf(stderr, "can not find lable %s\n",
entry->instruction.reloc_target);
}
}
}
for (entry = compiled_program.first;
entry != NULL;
entry = entry->next) {
if (!entry->islabel)
fprintf(output, " { 0x%08x, 0x%08x, 0x%08x, 0x%08x },\n",
((int *)(&entry->instruction))[0],
((int *)(&entry->instruction))[1],
((int *)(&entry->instruction))[2],
((int *)(&entry->instruction))[3]);
}
fflush (output);
if (ferror (output)) {
perror ("Could not flush output file");
if (output_file)
unlink (output_file);
err = 1;
}
return err;
}