On 30/04/2025 16:28, Li Zhijian wrote:
> 
> 
> On 30/04/2025 05:09, Peter Xu wrote:
>> On Thu, Mar 27, 2025 at 10:12:34AM +0800, Li Zhijian wrote:
>>> Recently, we removed ipv6 restriction[0] from RDMA migration, add a
>>> test for it.
>>>
>>> [0] 
>>> https://lore.kernel.org/qemu-devel/20250326095224.9918-1-jinpu.w...@ionos.com/
>>>
>>> Cc: Jack Wang <jinpu.w...@ionos.com>
>>> Cc: Michael R. Galaxy <mrgal...@nvidia.com>
>>> Cc: Peter Xu <pet...@redhat.com>
>>> Cc: Yu Zhang <yu.zh...@ionos.com>
>>> Signed-off-by: Li Zhijian <lizhij...@fujitsu.com>
>>> ---
>>>
>>> This test is added based on [1]
>>
>> Hmm, this cannot apply cleanly on top of your rdma test + Jake's ipv6 fix.
>> Did I made it wrong somewhere?
>>
>> At the meantime, I found that the current rdma unit test failing if I did
>> the "setup" phase then run this test without root:
>>
> 
> Thanks for you report, I reproduced it on fedora40 while ubuntu2204 always 
> works well.
> 
> I will look into it.

A work around in my fedora40 is:

$ sudo setcap 'cap_ipc_lock+ep' ./build/qemu-system-x86_64

Well, that's interesting, the ./build/qemu-system-x86_64 in my ubuntu2204 works
without cap_ipc_lock cap..


> 
> 
> Thanks
> Zhijian
> 
> 
>> stderr:
>> qemu-system-x86_64: cannot get rkey
>> qemu-system-x86_64: error while loading state section id 2(ram)
>> qemu-system-x86_64: load of migration failed: Operation not permitted
>> qemu-system-x86_64: rdma migration: recv polling control error!
>> qemu-system-x86_64: RDMA is in an error state waiting migration to abort!
>> qemu-system-x86_64: failed to save SaveStateEntry with id(name): 2(ram): -1
>> qemu-system-x86_64: Channel error: Operation not permitted
>> **
>> ERROR:../tests/qtest/migration/migration-qmp.c:200:check_migration_status: 
>> assertion failed (current_status != "failed"): ("failed" != "failed")
>> qemu-system-x86_64: warning: Early error. Sending error.
>> qemu-system-x86_64: warning: rdma migration: send polling control error
>> ../tests/qtest/libqtest.c:199: kill_qemu() tried to terminate QEMU process 
>> but encountered exit status 1 (expected 0)
>>
>> So running the test also needs root?  Is it possible we fix the test so it
>> can also be smart enough to skip if it knows it'll hit the "cannot get
>> rkey" error (even if it sees the rdma link setup)?  Not something urgent
>> but definitely good to have.

It seems it's a security problem, I have no a good idea yet.

Let me see see...




>>
>> OTOH, running the test using root always works for me.
> 
> 
>>
>>>
>>> Signed-off-by: Li Zhijian <lizhij...@fujitsu.com>
>>> ---
>>>   scripts/rdma-migration-helper.sh      | 26 +++++++++++++++++++++++---
>>>   tests/qtest/migration/precopy-tests.c | 21 +++++++++++++++++----
>>>   2 files changed, 40 insertions(+), 7 deletions(-)
>>>
>>> diff --git a/scripts/rdma-migration-helper.sh 
>>> b/scripts/rdma-migration-helper.sh
>>> index 019b9ad932..c358392b72 100755
>>> --- a/scripts/rdma-migration-helper.sh
>>> +++ b/scripts/rdma-migration-helper.sh
>>> @@ -8,6 +8,15 @@ get_ipv4_addr()
>>>           head -1 | tr -d '\n'
>>>   }
>>> +get_ipv6_addr() {
>>> +    ipv6=$(ip -6 -o addr show dev "$1" |
>>> +        sed -n 's/.*[[:blank:]]inet6[[:blank:]]*\([^[:blank:]/]*\).*/\1/p' 
>>> |
>>> +        head -1 | tr -d '\n')
>>> +
>>> +    [ $? -eq 0 ] || return
>>> +    echo -n ["$ipv6"%$1]
>>> +}
>>> +
>>>   # existing rdma interfaces
>>>   rdma_interfaces()
>>>   {
>>> @@ -20,11 +29,16 @@ ipv4_interfaces()
>>>       ip -o addr show | awk '/inet / {print $2}' | sort -u | grep -v -w lo
>>>   }
>>> +ipv6_interfaces()
>>> +{
>>> +    ip -o addr show | awk '/inet6 / {print $2}' | sort -u | grep -v -w lo
>>> +}
>>> +
>>>   rdma_rxe_detect()
>>>   {
>>>       for r in $(rdma_interfaces)
>>>       do
>>> -        ipv4_interfaces | grep -qw $r && get_ipv4_addr $r && return
>>> +        "$IP_FAMILY"_interfaces | grep -qw $r && get_"$IP_FAMILY"_addr $r 
>>> && return
>>>       done
>>>       return 1
>>> @@ -32,11 +46,11 @@ rdma_rxe_detect()
>>>   rdma_rxe_setup()
>>>   {
>>> -    for i in $(ipv4_interfaces)
>>> +    for i in $("$IP_FAMILY"_interfaces)
>>>       do
>>>           rdma_interfaces | grep -qw $i && continue
>>>           rdma link add "${i}_rxe" type rxe netdev "$i" && {
>>> -            echo "Setup new rdma/rxe ${i}_rxe for $i with $(get_ipv4_addr 
>>> $i)"
>>> +            echo "Setup new rdma/rxe ${i}_rxe for $i with 
>>> $(get_"$IP_FAMILY"_addr $i)"
>>>               return
>>>           }
>>>       done
>>> @@ -50,6 +64,12 @@ rdma_rxe_clean()
>>>       modprobe -r rdma_rxe
>>>   }
>>> +IP_FAMILY=${IP_FAMILY:-ipv4}
>>> +if [ "$IP_FAMILY" != "ipv6" ] && [ "$IP_FAMILY" != "ipv4" ]; then
>>> +    echo "Unknown ip family '$IP_FAMILY', only ipv4 or ipv6 is supported," 
>>> >&2
>>> +    exit 1
>>> +fi
>>> +
>>>   operation=${1:-detect}
>>>   command -v rdma >/dev/null || {
>>> diff --git a/tests/qtest/migration/precopy-tests.c 
>>> b/tests/qtest/migration/precopy-tests.c
>>> index a137ea9f2c..9f7236dc59 100644
>>> --- a/tests/qtest/migration/precopy-tests.c
>>> +++ b/tests/qtest/migration/precopy-tests.c
>>> @@ -102,12 +102,13 @@ static void test_precopy_unix_dirty_ring(void)
>>>   #ifdef CONFIG_RDMA
>>>   #define RDMA_MIGRATION_HELPER "scripts/rdma-migration-helper.sh"
>>> -static int new_rdma_link(char *buffer)
>>> +static int new_rdma_link(char *buffer, bool ipv6)
>>>   {
>>>       char cmd[256];
>>>       bool verbose = g_getenv("QTEST_LOG");
>>> -    snprintf(cmd, sizeof(cmd), "%s detect %s", RDMA_MIGRATION_HELPER,
>>> +    snprintf(cmd, sizeof(cmd), "IP_FAMILY=%s %s detect %s",
>>> +             ipv6 ? "ipv6" : "ipv4", RDMA_MIGRATION_HELPER,
>>>                verbose ? "" : "2>/dev/null");
>>>       FILE *pipe = popen(cmd, "r");
>>> @@ -132,11 +133,11 @@ static int new_rdma_link(char *buffer)
>>>       return -1;
>>>   }
>>> -static void test_precopy_rdma_plain(void)
>>> +static void test_precopy_rdma_plain_ip(bool ipv6)
>>>   {
>>>       char buffer[128] = {};
>>> -    if (new_rdma_link(buffer)) {
>>> +    if (new_rdma_link(buffer, ipv6)) {
>>>           g_test_skip("No rdma link available\n"
>>>                       "# To enable the test:\n"
>>>                       "# Run \'" RDMA_MIGRATION_HELPER " setup\' with root 
>>> to setup"
>>> @@ -159,6 +160,16 @@ static void test_precopy_rdma_plain(void)
>>>       test_precopy_common(&args);
>>>   }
>>> +
>>> +static void test_precopy_rdma_plain(void)
>>> +{
>>> +    test_precopy_rdma_plain_ip(0);
>>> +}
>>> +
>>> +static void test_precopy_rdma_plain_ipv6(void)
>>> +{
>>> +    test_precopy_rdma_plain_ip(1);
>>> +}
>>>   #endif
>>>   static void test_precopy_tcp_plain(void)
>>> @@ -1189,6 +1200,8 @@ static void 
>>> migration_test_add_precopy_smoke(MigrationTestEnv *env)
>>>   #ifdef CONFIG_RDMA
>>>       migration_test_add("/migration/precopy/rdma/plain",
>>>                          test_precopy_rdma_plain);
>>> +    migration_test_add("/migration/precopy/rdma/plain/ipv6",
>>> +                       test_precopy_rdma_plain_ipv6);
>>>   #endif
>>>   }
>>> -- 
>>> 2.41.0
>>>
>>

Reply via email to