0,0 → 1,100 |
/* |
* Copyright 2011 Christoph Bumiller |
* 2014 Red Hat Inc. |
* |
* 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 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. |
*/ |
|
#include "codegen/nv50_ir_target_gm107.h" |
#include "codegen/nv50_ir_lowering_gm107.h" |
|
namespace nv50_ir { |
|
Target *getTargetGM107(unsigned int chipset) |
{ |
return new TargetGM107(chipset); |
} |
|
// BULTINS / LIBRARY FUNCTIONS: |
|
// lazyness -> will just hardcode everything for the time being |
|
#include "lib/gm107.asm.h" |
|
void |
TargetGM107::getBuiltinCode(const uint32_t **code, uint32_t *size) const |
{ |
*code = (const uint32_t *)&gm107_builtin_code[0]; |
*size = sizeof(gm107_builtin_code); |
} |
|
uint32_t |
TargetGM107::getBuiltinOffset(int builtin) const |
{ |
assert(builtin < NVC0_BUILTIN_COUNT); |
return gm107_builtin_offsets[builtin]; |
} |
|
bool |
TargetGM107::isOpSupported(operation op, DataType ty) const |
{ |
switch (op) { |
case OP_MAD: |
case OP_FMA: |
if (ty != TYPE_F32) |
return false; |
break; |
case OP_SAD: |
case OP_POW: |
case OP_SQRT: |
case OP_DIV: |
case OP_MOD: |
return false; |
default: |
break; |
} |
|
return true; |
} |
|
bool |
TargetGM107::runLegalizePass(Program *prog, CGStage stage) const |
{ |
if (stage == CG_STAGE_PRE_SSA) { |
GM107LoweringPass pass(prog); |
return pass.run(prog, false, true); |
} else |
if (stage == CG_STAGE_POST_RA) { |
NVC0LegalizePostRA pass(prog); |
return pass.run(prog, false, true); |
} else |
if (stage == CG_STAGE_SSA) { |
NVC0LegalizeSSA pass; |
return pass.run(prog, false, true); |
} |
return false; |
} |
|
CodeEmitter * |
TargetGM107::getCodeEmitter(Program::Type type) |
{ |
return createCodeEmitterGM107(type); |
} |
|
} // namespace nv50_ir |