From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 083F2217658 for ; Thu, 9 Jan 2025 14:06:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736431612; cv=none; b=tRvPuRmyjdesMaPY0UL1keYFSEBH7AvFbYb/C0nr+kcA1TYZ3iHuKANmWuMdAGShYAcb2mQK5RtZFOMjvzOdJklLrf3yLmjigcogJTwwgmwCvR4DBsmgxrINpS5Bqkm6wpWMUUXYMhsa+69mxtEbcR+Ycv25DNEq2rm/ZpM29Zc= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736431612; c=relaxed/simple; bh=WwNHlWij6cUWaLoQi9J3IlfvCXoefxscyY8IJL/7GE4=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=BHxt0ihmdIFZpKRqT2vBTw5uxreykvpDilI4cMMKhyr/SXuXoaOrBhPAAv9ygoY4Ncw0rIEPmg4c0sA0DRnHQx9a2zQIGYBaCjAv34RR2ATGxF6pKedwaesS7dksxM2NWT9m2RTnPENe2ClFi6Nrk7e27UFEisJXlkX4VPXwjkY= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com; spf=pass smtp.mailfrom=oss.qualcomm.com; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b=YP8Kfpq2; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.qualcomm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com header.b="YP8Kfpq2" Received: from pps.filterd (m0279863.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 5099Nr8V008095 for ; Thu, 9 Jan 2025 14:06:50 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= mbArVg6/eRJ5CBY3wlWkBQa8h4VvimPAbHJu1V1shmY=; b=YP8Kfpq2GiAcqEuu 4uw9kQUSA199doBDfgyDTaI0jtv1L5zH8Xob4H96CzcFs7qsjjdxizFqfkbw6NjL vI67GCbr+XTjxVdHXh9uaIbFq30dJCo+Ts9S1HLk47Gyv1bBcpYr9ZFWoweSxSP5 rdJX8T8ANC2Wl7WWLlWtpm7waEKPzw94i8OjtLZtr7NhXzkHl7HZaVvhqQf96pbL thh0GdRTHJFWdTbVwxNCXVuipcJ63EgyR0yIh2IvRTeyqQ/SLTjq+3g+DtIyH51m Wmj2wm1+p3qcw6BoaBKZt8c0zZm5z2OgH4tVMv2k8V2rLHYR2DePUSddXSR+/JpS KhNR2A== Received: from mail-qt1-f198.google.com (mail-qt1-f198.google.com [209.85.160.198]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 442bsm8n9c-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Thu, 09 Jan 2025 14:06:50 +0000 (GMT) Received: by mail-qt1-f198.google.com with SMTP id d75a77b69052e-4679fb949e8so2301051cf.1 for ; Thu, 09 Jan 2025 06:06:50 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736431609; x=1737036409; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=mbArVg6/eRJ5CBY3wlWkBQa8h4VvimPAbHJu1V1shmY=; b=buYzrZovxsmXvQ8+sIbEfHSELfzOrZCT07W9jMRavnkN8Z4LpKq18a734okz/W74tQ 3qo5oVm3y4+Bzc696DF9K1CEKjDGvcW9nnvVgvohqxjh0zAbtUNFknzcusRAGI6o+MlS DxwG/C3ineW4YjvSMVnA+d5dko/WCEIkGpuUrj0VXCd2PgJDLJ6bDlE55nP/U3zF8r1Z KY38EILkQD/M6O6DFirTMh7tCtx983PGeAXRKUZsdmTzcpiMb+vcfEnnqdYzIe0ale2Y 3YHGt14dSmidNWTdwqXtNMHPp2FdBhvfgk0DmRtCIZU2EmersC8ydCddCDXnBKRxA1Ht VrkA== X-Forwarded-Encrypted: i=1; AJvYcCUvNdicLNPEX4xOWYbkn5/FacgwNBmVDVeSOToKZda7w47OC7cBI1Z+M1PHMEH7lP5SSgRXKeJT+WpM9PD1@vger.kernel.org X-Gm-Message-State: AOJu0YyM1ZWFtYOlJoJelC2Ii8M4Rr7Fs6vltJKy5ZvTLwu+SO1ERi05 +Fs1WA2mBdc6fG/4V354+nQQXri8crVLUQp5e+1+XvAH4TtYatHkyJ1wsh/JRPhQsETKzjPEzcn LT+rqEMfDi1EdWAOpBGpMvG3BzIzfH3vU0uusgd/GBfkn3ixxqy0qK0wZbeeqSgHD X-Gm-Gg: ASbGnctPpiPEsVFxi5P3kvMIMFcZFvLt5sErVTGg/Z3wn3gNuJ2PnnbSai/luxszkmk laftlNVDH/jmFrcZMGOxWgACJoek9MnrvU0QUfiU9PLuAZUHvwBeR6bJvssb/YV6bFxvLeJIx3b +G0I+PWQUiSbTyTMZZFpTjRXd9f5PUvUbhfxPzEfRZGsyy2UaX42yxZv5EZo83skG3/LcAusCDF +mgULBDqps9xyo1fCmt5EucQvgtT0Tsl7SCQPuhLJ5A4Llu5TvZ94RtvpQo3+4h9aIE3blPAFgs Js8yBh5Wc4U2pjNnpjcEFaafkAqesqhR63M= X-Received: by 2002:a05:622a:110c:b0:464:9463:7475 with SMTP id d75a77b69052e-46c7107797emr38702581cf.2.1736431608980; Thu, 09 Jan 2025 06:06:48 -0800 (PST) X-Google-Smtp-Source: AGHT+IHie2b0u8nYDuEHN0u3Cf6+ivLeBSXYRoFjZINs6QXJq5w2Zszg8fYJRiSalrgy7pO1187gXg== X-Received: by 2002:a05:622a:110c:b0:464:9463:7475 with SMTP id d75a77b69052e-46c7107797emr38702361cf.2.1736431608551; Thu, 09 Jan 2025 06:06:48 -0800 (PST) Received: from [192.168.65.90] (078088045245.garwolin.vectranet.pl. [78.88.45.245]) by smtp.gmail.com with ESMTPSA id a640c23a62f3a-ab2c95aee31sm74856766b.133.2025.01.09.06.06.46 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 09 Jan 2025 06:06:48 -0800 (PST) Message-ID: <308cd9f5-109c-4530-94c4-dd32eecf9ec3@oss.qualcomm.com> Date: Thu, 9 Jan 2025 15:06:45 +0100 Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [RFC PATCH 4/6] of: Extract alloc/add functions from of_platform_device_create_pdata() To: Stephen Boyd , Bjorn Andersson , Konrad Dybcio Cc: linux-kernel@vger.kernel.org, patches@lists.linux.dev, devicetree@vger.kernel.org, Dmitry Baryshkov , Krzysztof Kozlowski , Rob Herring , linux-arm-msm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Arnd Bergmann , Conor Dooley , Saravana Kannan , =?UTF-8?Q?Uwe_Kleine-K=C3=B6nig?= References: <20250108012846.3275443-1-swboyd@chromium.org> <20250108012846.3275443-5-swboyd@chromium.org> Content-Language: en-US From: Konrad Dybcio In-Reply-To: <20250108012846.3275443-5-swboyd@chromium.org> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Proofpoint-ORIG-GUID: GRTAaODFPvRZkDco3f9EOcc1DsQFsTnd X-Proofpoint-GUID: GRTAaODFPvRZkDco3f9EOcc1DsQFsTnd X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1039,Hydra:6.0.680,FMLib:17.12.60.29 definitions=2024-09-06_09,2024-09-06_01,2024-09-02_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 malwarescore=0 mlxlogscore=999 spamscore=0 impostorscore=0 priorityscore=1501 clxscore=1015 adultscore=0 phishscore=0 bulkscore=0 lowpriorityscore=0 suspectscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2411120000 definitions=main-2501090113 On 8.01.2025 2:28 AM, Stephen Boyd wrote: > Allow drivers to modify the 'struct device' for a device node by > splitting of_platform_device_create_pdata() into two functions. The > first function, of_platform_device_alloc(), allocates the platform > device and the second function, of_platform_device_add(), adds the > platform device to the platform bus. SoC power management drivers can > use these APIs to allocate a platform device for a node underneath the > soc node, attach pmdomains and/or set the device as runtime PM active, > and finally add the platform device to the platform bus. > > Cc: Rob Herring > Cc: Saravana Kannan > Cc: > Cc: Bjorn Andersson > Cc: Konrad Dybcio > Cc: > Signed-off-by: Stephen Boyd > --- [...] > +/** > + * of_platform_device_add - Add an of_device to the platform bus > + * @ofdev: of_device to add > + * > + * Return: 0 on success, negative errno on failure. > + */ > +int of_platform_device_add(struct platform_device *ofdev) > +{ > + struct device_node *np = ofdev->dev.of_node; > + int ret; > + > + pr_debug("adding platform device: %pOF\n", np); > + > + ret = of_device_add(ofdev); > + if (ret) { > + platform_device_put(ofdev); > + of_node_clear_flag(np, OF_POPULATED); > + } > + > + return ret; > +} > +EXPORT_SYMBOL(of_platform_device_add); > + > /** > * of_platform_device_create_pdata - Alloc, initialize and register an of_device > * @np: pointer to node to create device for > @@ -154,29 +214,19 @@ static struct platform_device *of_platform_device_create_pdata( > void *platform_data, > struct device *parent) > { > + int ret; > struct platform_device *dev; ultranit: you kept the reverse order above, please keep ret last too Konrad