[PATCH 3/5] nsi: Add a stub implementation of NsiEnumerateObjectsAllParameters().

Huw Davies huw at codeweavers.com
Mon Jun 28 02:01:04 CDT 2021


Signed-off-by: Huw Davies <huw at codeweavers.com>
---
 dlls/nsi/nsi.c       | 10 ++++++
 dlls/nsi/nsi.spec    |  2 +-
 dlls/nsi/tests/nsi.c | 72 +++++++++++++++++++++++++++++++++++++++++---
 include/wine/nsi.h   |  4 +++
 4 files changed, 82 insertions(+), 6 deletions(-)

diff --git a/dlls/nsi/nsi.c b/dlls/nsi/nsi.c
index bf52fe248c8..66054ffacd6 100644
--- a/dlls/nsi/nsi.c
+++ b/dlls/nsi/nsi.c
@@ -38,6 +38,16 @@ DWORD WINAPI NsiAllocateAndGetTable( DWORD unk, const NPI_MODULEID *module, DWOR
     return ERROR_CALL_NOT_IMPLEMENTED;
 }
 
+DWORD WINAPI NsiEnumerateObjectsAllParameters( DWORD unk, DWORD unk2, const NPI_MODULEID *module, DWORD table,
+                                               void *key_data, DWORD key_size, void *rw_data, DWORD rw_size,
+                                               void *dynamic_data, DWORD dynamic_size, void *static_data, DWORD static_size,
+                                               DWORD *count )
+{
+    FIXME( "%d %d %p %d %p %d %p %d %p %d %p %d %p: stub\n", unk, unk2, module, table, key_data, key_size,
+           rw_data, rw_size, dynamic_data, dynamic_size, static_data, static_size, count );
+    return ERROR_CALL_NOT_IMPLEMENTED;
+}
+
 void WINAPI NsiFreeTable( void *key_data, void *rw_data, void *dynamic_data, void *static_data )
 {
     FIXME( "%p %p %p %p: stub\n", key_data, rw_data, dynamic_data, static_data );
diff --git a/dlls/nsi/nsi.spec b/dlls/nsi/nsi.spec
index 46757988146..d4a29c38fe6 100644
--- a/dlls/nsi/nsi.spec
+++ b/dlls/nsi/nsi.spec
@@ -3,7 +3,7 @@
 @ stub NsiCancelChangeNotification
 @ stub NsiDeregisterChangeNotification
 @ stub NsiDeregisterChangeNotificationEx
-@ stub NsiEnumerateObjectsAllParameters
+@ stdcall NsiEnumerateObjectsAllParameters(long long ptr long ptr long ptr long ptr long ptr long ptr)
 @ stub NsiEnumerateObjectsAllParametersEx
 @ stub NsiEnumerateObjectsAllPersistentParametersWithMask
 @ stub NsiFreePersistentDataWithMaskTable
diff --git a/dlls/nsi/tests/nsi.c b/dlls/nsi/tests/nsi.c
index 72c9dcdccbd..b1befd548cd 100644
--- a/dlls/nsi/tests/nsi.c
+++ b/dlls/nsi/tests/nsi.c
@@ -37,11 +37,11 @@ static void test_nsi_api( void )
 {
     DWORD rw_sizes[] = { FIELD_OFFSET(struct nsi_ndis_ifinfo_rw, name2), FIELD_OFFSET(struct nsi_ndis_ifinfo_rw, unk),
                          sizeof(struct nsi_ndis_ifinfo_rw) };
-    struct nsi_ndis_ifinfo_rw *rw_tbl, *rw, get_rw;
-    struct nsi_ndis_ifinfo_dynamic *dyn_tbl, *dyn, get_dyn;
-    struct nsi_ndis_ifinfo_static *stat_tbl, *stat, get_stat;
-    DWORD err, count, i, rw_size;
-    NET_LUID *luid_tbl;
+    struct nsi_ndis_ifinfo_rw *rw_tbl, *rw, get_rw, *enum_rw_tbl, *enum_rw;
+    struct nsi_ndis_ifinfo_dynamic *dyn_tbl, *dyn, get_dyn, *enum_dyn_tbl, *enum_dyn;
+    struct nsi_ndis_ifinfo_static *stat_tbl, *stat, get_stat, *enum_stat_tbl, *enum_stat;
+    DWORD err, count, i, rw_size, enum_count;
+    NET_LUID *luid_tbl, *enum_luid_tbl;
 
     /* Use the NDIS ifinfo table to test various api */
     for (i = 0; i < ARRAY_SIZE(rw_sizes); i++)
@@ -101,6 +101,68 @@ todo_wine
         winetest_pop_context();
     }
 
+    enum_count = 0;
+    err = NsiEnumerateObjectsAllParameters( 1, 1, &NPI_MS_NDIS_MODULEID, NSI_NDIS_IFINFO_TABLE,
+                                            NULL, 0, NULL, 0,
+                                            NULL, 0, NULL, 0, &enum_count );
+    ok( !err, "got %d\n", err );
+    ok( enum_count == count, "mismatch\n" );
+
+    enum_luid_tbl = malloc( count * sizeof(*enum_luid_tbl) );
+    enum_rw_tbl = malloc( count * rw_size );
+    enum_dyn_tbl = malloc( count * sizeof(*enum_dyn_tbl) );
+    enum_stat_tbl = malloc( count * sizeof(*enum_stat_tbl) );
+
+    err = NsiEnumerateObjectsAllParameters( 1, 1, &NPI_MS_NDIS_MODULEID, NSI_NDIS_IFINFO_TABLE,
+                                            enum_luid_tbl, sizeof(*enum_luid_tbl), enum_rw_tbl, rw_size,
+                                            enum_dyn_tbl, sizeof(*enum_dyn_tbl), enum_stat_tbl, sizeof(*enum_stat_tbl),
+                                            &enum_count );
+    ok( !err, "got %d\n", err );
+    ok( enum_count == count, "mismatch\n" );
+
+    for (i = 0; i < count; i++)
+    {
+        winetest_push_context( "%d", i );
+        rw = (struct nsi_ndis_ifinfo_rw *)((BYTE *)rw_tbl + i * rw_size);
+        enum_rw = (struct nsi_ndis_ifinfo_rw *)((BYTE *)enum_rw_tbl + i * rw_size);
+        dyn = dyn_tbl + i;
+        enum_dyn = enum_dyn_tbl + i;
+        stat = stat_tbl + i;
+        enum_stat = enum_stat_tbl + i;
+
+        /* test a selection of members */
+        ok( enum_luid_tbl[i].Value == luid_tbl[i].Value, "mismatch\n" );
+        ok( IsEqualGUID( &enum_rw->network_guid, &rw->network_guid ), "mismatch\n" );
+        ok( enum_rw->alias.Length == rw->alias.Length, "mismatch\n" );
+        ok( !memcmp( enum_rw->alias.String, rw->alias.String, rw->alias.Length ), "mismatch\n" );
+        ok( enum_rw->phys_addr.Length == rw->phys_addr.Length, "mismatch\n" );
+        ok( !memcmp( enum_rw->phys_addr.Address, rw->phys_addr.Address, IF_MAX_PHYS_ADDRESS_LENGTH ), "mismatch\n" );
+        ok( enum_dyn->oper_status == dyn->oper_status, "mismatch\n" );
+        ok( enum_stat->if_index == stat->if_index, "mismatch\n" );
+        ok( IsEqualGUID( &enum_stat->if_guid, &stat->if_guid ), "mismatch\n" );
+        winetest_pop_context();
+    }
+
+    if (count > 0)
+    {
+        enum_count--;
+        memset( enum_luid_tbl, 0xcc, count * sizeof(*enum_luid_tbl) );
+
+        err = NsiEnumerateObjectsAllParameters( 1, 1, &NPI_MS_NDIS_MODULEID, NSI_NDIS_IFINFO_TABLE,
+                                                enum_luid_tbl, sizeof(*enum_luid_tbl), enum_rw_tbl, rw_size,
+                                                enum_dyn_tbl, sizeof(*enum_dyn_tbl), enum_stat_tbl, sizeof(*enum_stat_tbl),
+                                                &enum_count );
+        ok( err == ERROR_MORE_DATA, "got %d\n", err );
+        ok( enum_count == count - 1, "mismatch\n" );
+
+        for (i = 0; i < enum_count; i++) /* for simplicity just check the luids */
+            ok( enum_luid_tbl[i].Value == luid_tbl[i].Value, "%d: mismatch\n", i );
+    }
+
+    free( enum_luid_tbl );
+    free( enum_rw_tbl );
+    free( enum_dyn_tbl );
+    free( enum_stat_tbl );
     NsiFreeTable( luid_tbl, rw_tbl, dyn_tbl, stat_tbl );
 }
 
diff --git a/include/wine/nsi.h b/include/wine/nsi.h
index 8b276e76b82..8fd16dd9d97 100644
--- a/include/wine/nsi.h
+++ b/include/wine/nsi.h
@@ -96,6 +96,10 @@ struct nsi_ndis_ifinfo_static
 DWORD WINAPI NsiAllocateAndGetTable( DWORD unk, const NPI_MODULEID *module, DWORD table, void **key_data, DWORD key_size,
                                      void **rw_data, DWORD rw_size, void **dynamic_data, DWORD dynamic_size,
                                      void **static_data, DWORD static_size, DWORD *count, DWORD unk2 );
+DWORD WINAPI NsiEnumerateObjectsAllParameters( DWORD unk, DWORD unk2, const NPI_MODULEID *module, DWORD table,
+                                               void *key_data, DWORD key_size, void *rw_data, DWORD rw_size,
+                                               void *dynamic_data, DWORD dynamic_size, void *static_data, DWORD static_size,
+                                               DWORD *count );
 void WINAPI NsiFreeTable( void *key_data, void *rw_data, void *dynamic_data, void *static_data );
 DWORD WINAPI NsiGetAllParameters( DWORD unk, const NPI_MODULEID *module, DWORD table, const void *key, DWORD key_size,
                                   void *rw_data, DWORD rw_size, void *dynamic_data, DWORD dynamic_size,
-- 
2.23.0




More information about the wine-devel mailing list