Modules/VESA - Hide cursor when not LFB mode
[tpg/acess2.git] / KernelLand / Modules / Interfaces / UDI / management_agent.c
index 512fda3..ec815d4 100644 (file)
@@ -49,9 +49,11 @@ tUDI_DriverInstance *UDI_MA_CreateInstance(tUDI_DriverModule *DriverModule,
 //     UDI_BindChannel_Raw(inst->ManagementChannel, false,
 //             NULL, 1, inst, &cUDI_MgmtOpsList);      // TODO: ops list for management agent?
 
-       for( int i = 0; i < DriverModule->nRegions; i ++ )
-               Log("Rgn %i: %p", i, inst->Regions[i]);
+//     for( int i = 0; i < DriverModule->nRegions; i ++ )
+//             Log("Rgn %i: %p", i, inst->Regions[i]);
 
+       LOG("Inst %s %p MA state =%i",
+               inst->Module->ModuleName, inst, UDI_MASTATE_USAGEIND);
        inst->CurState = UDI_MASTATE_USAGEIND;
        // Next State: _SECBIND
 
@@ -184,14 +186,17 @@ void UDI_MA_AddChild(udi_enumerate_cb_t *cb, udi_index_t ops_idx)
        inst->FirstChild = child;
        
        // and search for a handler
-       tUDI_MetaLang   *metalang = UDI_int_GetMetaLang(inst, child->Ops->meta_idx);
+       child->Metalang = UDI_int_GetMetaLang(inst->Module, child->Ops->meta_idx);
         int    best_level = 0;
        tUDI_DriverModule *best_module = NULL;
        for( tUDI_DriverModule *module = gpUDI_LoadedModules; module; module = module->Next )
        {
                for( int i = 0; i < module->nDevices; i ++ )
                {
-                       if( module->Devices[i]->Metalang != metalang )
+                       //LOG("%s:%i %p ?== %p",
+                       //      module->ModuleName, i,
+                       //      module->Devices[i]->Metalang, metalang);
+                       if( module->Devices[i]->Metalang != child->Metalang )
                                continue ;
                        
                        int level = UDI_MA_CheckDeviceMatch(
@@ -223,6 +228,8 @@ void UDI_MA_BindParents(tUDI_DriverModule *Module)
                        {
                                if( child->BoundInstance )
                                        continue ;
+                               if( Module->Devices[i]->Metalang != child->Metalang )
+                                       continue ;
                                // Check for match
                                int level = UDI_MA_CheckDeviceMatch(
                                        Module->Devices[i]->nAttribs, Module->Devices[i]->Attribs,
@@ -244,6 +251,9 @@ void UDI_MA_TransitionState(tUDI_DriverInstance *Inst, enum eUDI_MAState Src, en
        if( Inst->CurState != Src )
                return ;
        
+       LOG("Inst %s %p MA state %i->%i",
+               Inst->Module->ModuleName, Inst, Src, Dst);
+       
        switch(Dst)
        {
        case UDI_MASTATE_USAGEIND:
@@ -270,7 +280,7 @@ void UDI_MA_TransitionState(tUDI_DriverInstance *Inst, enum eUDI_MAState Src, en
                        
                        // Bind to parent
                        tUDI_BindOps    *parent = &Module->Parents[0];
-                       udi_channel_t channel = UDI_CreateChannel_Blank(UDI_int_GetMetaLang(Inst, parent->meta_idx));
+                       udi_channel_t channel = UDI_CreateChannel_Blank(UDI_int_GetMetaLang(Inst->Module, parent->meta_idx));
                        
                        UDI_BindChannel(channel,true,  Inst, parent->ops_idx, parent->region_idx, NULL,false,0);
                        UDI_BindChannel(channel,false,

UCC git Repository :: git.ucc.asn.au