On Fri, Oct 30, 2015 at 01:55:59PM +0800, Xiao Guangrong wrote: > Implement ObjectType which is used by NVDIMM _DSM method in > later patch > > Signed-off-by: Xiao Guangrong <guangrong.x...@linux.intel.com>
I had to go dig in the _DSM patch to see how it's used. And sure enough, callers have to know AML to make sense of it. So pls don't split out tiny patches like this. include the callee with the caller. > --- > hw/acpi/aml-build.c | 8 ++++++++ > include/hw/acpi/aml-build.h | 1 + > 2 files changed, 9 insertions(+) > > diff --git a/hw/acpi/aml-build.c b/hw/acpi/aml-build.c > index efc06ab..9f792ab 100644 > --- a/hw/acpi/aml-build.c > +++ b/hw/acpi/aml-build.c > @@ -1178,6 +1178,14 @@ Aml *aml_concatenate(Aml *source1, Aml *source2, Aml > *target) > return var; > } > > +/* ACPI 1.0b: 16.2.5.4 Type 2 Opcodes Encoding: DefObjectType */ > +Aml *aml_object_type(Aml *object) > +{ > + Aml *var = aml_opcode(0x8E /* ObjectTypeOp */); > + aml_append(var, object); > + return var; > +} > + It would be better to have a higher level API that can be used without knowning AML. For example: aml_object_type_is_package() > void > build_header(GArray *linker, GArray *table_data, > AcpiTableHeader *h, const char *sig, int len, uint8_t rev) > diff --git a/include/hw/acpi/aml-build.h b/include/hw/acpi/aml-build.h > index 325782d..5b8a118 100644 > --- a/include/hw/acpi/aml-build.h > +++ b/include/hw/acpi/aml-build.h > @@ -278,6 +278,7 @@ Aml *aml_derefof(Aml *arg); > Aml *aml_sizeof(Aml *arg); > Aml *aml_create_field(Aml *srcbuf, Aml *index, Aml *len, const char *name); > Aml *aml_concatenate(Aml *source1, Aml *source2, Aml *target); > +Aml *aml_object_type(Aml *object); > > void > build_header(GArray *linker, GArray *table_data, > -- > 1.8.3.1